var define, require, esl;
!function(e) {
    function t(e) {
        m(e, J) || (O[e] = 1)
    }
    function i(e, t) {
        function i(e) {
            0 === e.indexOf(".") && a.push(e)
        }
        var a = [];
        if ("string" == typeof e ? i(e) : C(e, function(e) {
            i(e)
        }), a.length > 0)
            throw new Error("[REQUIRE_FATAL]Relative ID is not allowed in global require: " + a.join(", "));
        var o = N.waitSeconds;
        return o && e instanceof Array && (E && clearTimeout(E), E = setTimeout(n, 1e3 * o)), D(e, t)
    }
    function n() {
        function e(r, s) {
            if (!o[r] && !m(r, J)) {
                o[r] = 1, m(r, F) || n[r] || (n[r] = 1, t.push(r));
                var l = z[r];
                l ? s && (n[r] || (n[r] = 1, t.push(r)), C(l.depMs, function(t) {
                    e(t.absId, t.hard)
                })) : a[r] || (a[r] = 1, i.push(r))
            }
        }
        var t = [], i = [], n = {}, a = {}, o = {};
        for (var r in O)
            e(r, 1);
        if (t.length || i.length)
            throw new Error("[MODULE_TIMEOUT]Hang( " + (t.join(", ") || "none") + " ) Miss( " + (i.join(", ") || "none") + " )")
    }
    function a(e) {
        C(B, function(t) {
            s(e, t.deps, t.factory)
        }), B.length = 0
    }
    function o(e, t, i) {
        if (null == i && (null == t ? (i = e, e = null) : (i = t, t = null, e instanceof Array && (t = e, e = null))), null != i) {
            var n = window.opera;
            if (!e && document.attachEvent && (!n || "[object Opera]" !== n.toString())) {
                var a = I();
                e = a && a.getAttribute("data-require-id")
            }
            e ? s(e, t, i) : B[0] = {deps: t,factory: i}
        }
    }
    function r() {
        var e = N.config[this.id];
        return e && "object" == typeof e ? e : {}
    }
    function s(e, t, i) {
        z[e] || (z[e] = {id: e,depsDec: t,deps: t || ["require", "exports", "module"],factoryDeps: [],factory: i,exports: {},config: r,state: A,require: v(e),depMs: [],depMkv: {},depRs: []})
    }
    function l(e) {
        var t = z[e];
        if (t && !m(e, M)) {
            var i = t.deps, n = t.factory, a = 0;
            "function" == typeof n && (a = Math.min(n.length, i.length), !t.depsDec && n.toString().replace(/(\/\*([\s\S]*?)\*\/|([^:]|^)\/\/(.*)$)/gm, "").replace(/require\(\s*(['"'])([^'"]+)\1\s*\)/g, function(e, t, n) {
                i.push(n)
            }));
            var o = [], r = [];
            C(i, function(i, n) {
                var s, l, h = W(i), d = L(h.mod, e);
                d && !P[d] ? (h.res && (l = {id: i,mod: d,res: h.res}, r.push(i), t.depRs.push(l)), s = t.depMkv[d], s || (s = {id: h.mod,absId: d,hard: a > n}, t.depMs.push(s), t.depMkv[d] = s, o.push(d))) : s = {absId: d}, a > n && t.factoryDeps.push(l || s)
            }), t.state = M, c(e), g(o), r.length && t.require(r, function() {
                C(t.depRs, function(t) {
                    t.absId || (t.absId = L(t.id, e))
                }), h()
            })
        }
    }
    function h() {
        for (var e in O)
            l(e), d(e), p(e)
    }
    function d(e) {
        function t(e) {
            if (l(e), !m(e, M))
                return !1;
            if (m(e, F) || i[e])
                return !0;
            i[e] = 1;
            var n = z[e], a = !0;
            return C(n.depMs, function(e) {
                return a = t(e.absId)
            }), a && C(n.depRs, function(e) {
                return a = !!e.absId
            }), a && (n.state = F), a
        }
        var i = {};
        t(e)
    }
    function c(t) {
        function i() {
            if (!n && a.state === F) {
                n = 1;
                var i = 1;
                if (C(a.factoryDeps, function(e) {
                    var t = e.absId;
                    return P[t] ? void 0 : (p(t), i = m(t, J))
                }), i) {
                    try {
                        var o = a.factory, r = "function" == typeof o ? o.apply(e, u(a.factoryDeps, {require: a.require,exports: a.exports,module: a})) : o;
                        null != r && (a.exports = r), a.invokeFactory = null
                    } catch (s) {
                        if (/^\[MODULE_MISS\]"([^"]+)/.test(s.message)) {
                            var l = a.depMkv[RegExp.$1];
                            return l && (l.hard = 1), void (n = 0)
                        }
                        throw s
                    }
                    U(t)
                }
            }
        }
        var n, a = z[t];
        a.invokeFactory = i
    }
    function m(e, t) {
        return z[e] && z[e].state >= t
    }
    function p(e) {
        var t = z[e];
        t && t.invokeFactory && t.invokeFactory()
    }
    function u(e, t) {
        var i = [];
        return C(e, function(e, n) {
            "object" == typeof e && (e = e.absId), i[n] = t[e] || z[e].exports
        }), i
    }
    function V(e, t) {
        if (m(e, J))
            return void t();
        var i = H[e];
        i || (i = H[e] = []), i.push(t)
    }
    function U(e) {
        var t = z[e];
        t.state = J, delete O[e];
        for (var i = H[e] || [], n = i.length; n--; )
            i[n]();
        i.length = 0, H[e] = null
    }
    function g(t, i, n) {
        function a() {
            if ("function" == typeof i && !o) {
                var n = 1;
                C(t, function(e) {
                    return P[e] ? void 0 : n = !!m(e, J)
                }), n && (o = 1, i.apply(e, u(t, P)))
            }
        }
        var o = 0;
        C(t, function(e) {
            P[e] || m(e, J) || (V(e, a), (e.indexOf("!") > 0 ? y : f)(e, n))
        }), a()
    }
    function f(t) {
        function i() {
            var e = Q[t];
            S(e || t, n)
        }
        function n() {
            if (r) {
                var i;
                "function" == typeof r.init && (i = r.init.apply(e, u(s, P))), null == i && r.exports && (i = e, C(r.exports.split("."), function(e) {
                    return i = i[e], !!i
                })), o(t, s, i || {})
            } else
                a(t);
            h()
        }
        if (!R[t] && !z[t]) {
            R[t] = 1;
            var r = N.shim[t];
            r instanceof Array && (N.shim[t] = r = {deps: r});
            var s = r && (r.deps || []);
            s ? (C(s, function(e) {
                N.shim[e] || (N.shim[e] = {})
            }), D(s, i)) : i()
        }
    }
    function y(e, t) {
        function i(t) {
            l.exports = t || !0, U(e)
        }
        function n(n) {
            var a = t ? z[t].require : D;
            n.load(s.res, a, i, r.call({id: e}))
        }
        if (!z[e]) {
            var o = Q[e];
            if (o)
                return void f(o);
            var s = W(e), l = {id: e,state: M};
            z[e] = l, i.fromText = function(e, t) {
                new Function(t)(), a(e)
            }, n(D(s.mod))
        }
    }
    function b(e, t) {
        var i = X(e, 1, t);
        return i.sort(T), i
    }
    function _() {
        function e(e) {
            Q[e] = t
        }
        N.baseUrl = N.baseUrl.replace(/\/$/, "") + "/", G = b(N.paths), Z = b(N.map, 1), C(Z, function(e) {
            e.v = b(e.v)
        }), Y = [], C(N.packages, function(e) {
            var t = e;
            "string" == typeof e && (t = {name: e.split("/")[0],location: e,main: "main"}), t.location = t.location || t.name, t.main = (t.main || "main").replace(/\.js$/i, ""), t.reg = K(t.name), Y.push(t)
        }), Y.sort(T), q = b(N.urlArgs, 1), Q = {};
        for (var t in N.bundles)
            C(N.bundles[t], e)
    }
    function x(e, t, i) {
        C(t, function(t) {
            return t.reg.test(e) ? (i(t.v, t.k, t), !1) : void 0
        })
    }
    function k(e) {
        var t = /(\.[a-z0-9]+)$/i, i = /(\?[^#]*)$/, n = "", a = e, o = "";
        i.test(e) && (o = RegExp.$1, e = e.replace(i, "")), t.test(e) && (n = RegExp.$1, a = e.replace(t, ""));
        var r, s = a;
        return x(a, G, function(e, t) {
            s = s.replace(t, e), r = 1
        }), r || x(a, Y, function(e, t, i) {
            s = s.replace(i.name, i.location)
        }), /^([a-z]{2,10}:\/)?\//i.test(s) || (s = N.baseUrl + s), s += n + o, x(a, q, function(e) {
            s += (s.indexOf("?") > 0 ? "&" : "?") + e
        }), s
    }
    function v(e) {
        function i(i, a) {
            if ("string" == typeof i) {
                if (!n[i]) {
                    var o = L(i, e);
                    if (p(o), !m(o, J))
                        throw new Error('[MODULE_MISS]"' + o + '" is not exists!');
                    n[i] = z[o].exports
                }
                return n[i]
            }
            if (i instanceof Array) {
                var r = [], s = [];
                C(i, function(i, n) {
                    var a = W(i), o = L(a.mod, e), l = a.res, h = o;
                    if (l) {
                        var d = o + "!" + l;
                        0 !== l.indexOf(".") && Q[d] ? o = h = d : h = null
                    }
                    s[n] = h, t(o), r.push(o)
                }), g(r, function() {
                    C(s, function(n, a) {
                        null == n && (n = s[a] = L(i[a], e), t(n))
                    }), g(s, a, e), h()
                }, e), h()
            }
        }
        var n = {};
        return i.toUrl = function(t) {
            return k(L(t, e))
        }, i
    }
    function L(e, t) {
        if (!e)
            return "";
        t = t || "";
        var i = W(e);
        if (!i)
            return e;
        var n = i.res, a = w(i.mod, t);
        if (C(Y, function(e) {
            var t = e.name;
            return t === a ? (a = t + "/" + e.main, !1) : void 0
        }), x(t, Z, function(e) {
            x(a, e, function(e, t) {
                a = a.replace(t, e)
            })
        }), n) {
            var o = m(a, J) && D(a);
            n = o && o.normalize ? o.normalize(n, function(e) {
                return L(e, t)
            }) : L(n, t), a += "!" + n
        }
        return a
    }
    function w(e, t) {
        if (0 === e.indexOf(".")) {
            var i = t.split("/"), n = e.split("/"), a = i.length - 1, o = n.length, r = 0, s = 0;
            e: for (var l = 0; o > l; l++)
                switch (n[l]) {
                    case "..":
                        if (!(a > r))
                            break e;
                        r++, s++;
                        break;
                    case ".":
                        s++;
                        break;
                    default:
                        break e
                }
            return i.length = a - r, n = n.slice(s), i.concat(n).join("/")
        }
        return e
    }
    function W(e) {
        var t = e.split("!");
        return t[0] ? {mod: t[0],res: t[1]} : void 0
    }
    function X(e, t, i) {
        var n = [];
        for (var a in e)
            if (e.hasOwnProperty(a)) {
                var o = {k: a,v: e[a]};
                n.push(o), t && (o.reg = "*" === a && i ? /^/ : K(a))
            }
        return n
    }
    function I() {
        if (j)
            return j;
        if ($ && "interactive" === $.readyState)
            return $;
        for (var e = document.getElementsByTagName("script"), t = e.length; t--; ) {
            var i = e[t];
            if ("interactive" === i.readyState)
                return $ = i, i
        }
    }
    function S(e, t) {
        function i() {
            var e = n.readyState;
            ("undefined" == typeof e || /^(loaded|complete)$/.test(e)) && (n.onload = n.onreadystatechange = null, n = null, t())
        }
        var n = document.createElement("script");
        n.setAttribute("data-require-id", e), n.src = k(e + ".js"), n.async = !0, n.readyState ? n.onreadystatechange = i : n.onload = i, j = n, te ? ee.insertBefore(n, te) : ee.appendChild(n), j = null
    }
    function K(e) {
        return new RegExp("^" + e + "(/|$)")
    }
    function C(e, t) {
        if (e instanceof Array)
            for (var i = 0, n = e.length; n > i && t(e[i], i) !== !1; i++)
                ;
    }
    function T(e, t) {
        var i = e.k || e.name, n = t.k || t.name;
        return "*" === n ? -1 : "*" === i ? 1 : n.length - i.length
    }
    var E, z = {}, A = 1, M = 2, F = 3, J = 4, O = {}, P = {require: i,exports: 1,module: 1}, D = v(), N = {baseUrl: "./",paths: {},config: {},map: {},packages: [],shim: {},waitSeconds: 0,bundles: {},urlArgs: {}};
    i.version = "2.0.2", i.loader = "esl", i.toUrl = D.toUrl;
    var B = [];
    o.amd = {};
    var H = {}, R = {};
    i.config = function(e) {
        if (e) {
            for (var t in N) {
                var i = e[t], n = N[t];
                if (i)
                    if ("urlArgs" === t && "string" == typeof i)
                        N.urlArgs["*"] = i;
                    else if (n instanceof Array)
                        n.push.apply(n, i);
                    else if ("object" == typeof n)
                        for (var a in i)
                            n[a] = i[a];
                    else
                        N[t] = i
            }
            _()
        }
    }, _();
    var G, Y, Z, Q, q, j, $, ee = document.getElementsByTagName("head")[0], te = document.getElementsByTagName("base")[0];
    te && (ee = te.parentNode), define || (define = o, require || (require = i), esl = i)
}(this), define("echarts", ["echarts/echarts"], function(e) {
    return e
}), define("echarts/echarts", ["require", "./config", "zrender/tool/util", "zrender/tool/event", "zrender/tool/env", "zrender", "zrender/config", "./chart/island", "./component/toolbox", "./component", "./component/title", "./component/tooltip", "./component/legend", "./util/ecData", "./chart", "zrender/tool/color", "./component/timeline", "zrender/shape/Image", "zrender/loadingEffect/Bar", "zrender/loadingEffect/Bubble", "zrender/loadingEffect/DynamicLine", "zrender/loadingEffect/Ring", "zrender/loadingEffect/Spin", "zrender/loadingEffect/Whirling", "./theme/macarons", "./theme/infographic"], function(e) {
    function t() {
        r.Dispatcher.call(this)
    }
    function i(e) {
        e.innerHTML = "", this._themeConfig = {}, this.dom = e, this._connected = !1, this._status = {dragIn: !1,dragOut: !1,needRefresh: !1}, this._curEventType = !1, this._chartList = [], this._messageCenter = new t, this._messageCenterOutSide = new t, this.resize = this.resize(), this._init()
    }
    function n(e, t, i, n, a) {
        for (var o = e._chartList, r = o.length; r--; ) {
            var s = o[r];
            "function" == typeof s[t] && s[t](i, n, a)
        }
    }
    var a = e("./config"), o = e("zrender/tool/util"), r = e("zrender/tool/event"), s = {}, l = e("zrender/tool/env").canvasSupported, h = new Date - 0, d = {}, c = "_echarts_instance_";
    s.version = "2.2.7", s.dependencies = {zrender: "2.1.1"}, s.init = function(t, n) {
        var a = e("zrender");
        a.version.replace(".", "") - 0 < s.dependencies.zrender.replace(".", "") - 0 && console.error("ZRender " + a.version + " is too old for ECharts " + s.version + ". Current version need ZRender " + s.dependencies.zrender + "+"), t = t instanceof Array ? t[0] : t;
        var o = t.getAttribute(c);
        return o || (o = h++, t.setAttribute(c, o)), d[o] && d[o].dispose(), d[o] = new i(t), d[o].id = o, d[o].canvasSupported = l, d[o].setTheme(n), d[o]
    }, s.getInstanceById = function(e) {
        return d[e]
    }, o.merge(t.prototype, r.Dispatcher.prototype, !0);
    var m = e("zrender/config").EVENT, p = ["CLICK", "DBLCLICK", "MOUSEOVER", "MOUSEOUT", "DRAGSTART", "DRAGEND", "DRAGENTER", "DRAGOVER", "DRAGLEAVE", "DROP"];
    return i.prototype = {_init: function() {
            var t = this, i = e("zrender").init(this.dom);
            this._zr = i, this._messageCenter.dispatch = function(e, i, n, a) {
                n = n || {}, n.type = e, n.event = i, t._messageCenter.dispatchWithContext(e, n, a), t._messageCenterOutSide.dispatchWithContext(e, n, a)
            }, this._onevent = function(e) {
                return t.__onevent(e)
            };
            for (var n in a.EVENT)
                "CLICK" != n && "DBLCLICK" != n && "HOVER" != n && "MOUSEOUT" != n && "MAP_ROAM" != n && this._messageCenter.bind(a.EVENT[n], this._onevent, this);
            var o = {};
            this._onzrevent = function(e) {
                return t[o[e.type]](e)
            };
            for (var r = 0, s = p.length; s > r; r++) {
                var l = p[r], h = m[l];
                o[h] = "_on" + l.toLowerCase(), i.on(h, this._onzrevent)
            }
            this.chart = {}, this.component = {};
            var d = e("./chart/island");
            this._island = new d(this._themeConfig, this._messageCenter, i, {}, this), this.chart.island = this._island;
            var c = e("./component/toolbox");
            this._toolbox = new c(this._themeConfig, this._messageCenter, i, {}, this), this.component.toolbox = this._toolbox;
            var u = e("./component");
            u.define("title", e("./component/title")), u.define("tooltip", e("./component/tooltip")), u.define("legend", e("./component/legend")), (0 === i.getWidth() || 0 === i.getHeight()) && console.error("Dom’s width & height should be ready before init.")
        },__onevent: function(e) {
            e.__echartsId = e.__echartsId || this.id;
            var t = e.__echartsId === this.id;
            switch (this._curEventType || (this._curEventType = e.type), e.type) {
                case a.EVENT.LEGEND_SELECTED:
                    this._onlegendSelected(e);
                    break;
                case a.EVENT.DATA_ZOOM:
                    if (!t) {
                        var i = this.component.dataZoom;
                        i && (i.silence(!0), i.absoluteZoom(e.zoom), i.silence(!1))
                    }
                    this._ondataZoom(e);
                    break;
                case a.EVENT.DATA_RANGE:
                    t && this._ondataRange(e);
                    break;
                case a.EVENT.MAGIC_TYPE_CHANGED:
                    if (!t) {
                        var n = this.component.toolbox;
                        n && (n.silence(!0), n.setMagicType(e.magicType), n.silence(!1))
                    }
                    this._onmagicTypeChanged(e);
                    break;
                case a.EVENT.DATA_VIEW_CHANGED:
                    t && this._ondataViewChanged(e);
                    break;
                case a.EVENT.TOOLTIP_HOVER:
                    t && this._tooltipHover(e);
                    break;
                case a.EVENT.RESTORE:
                    this._onrestore();
                    break;
                case a.EVENT.REFRESH:
                    t && this._onrefresh(e);
                    break;
                case a.EVENT.TOOLTIP_IN_GRID:
                case a.EVENT.TOOLTIP_OUT_GRID:
                    if (t) {
                        if (this._connected) {
                            var o = this.component.grid;
                            o && (e.x = (e.event.zrenderX - o.getX()) / o.getWidth(), e.y = (e.event.zrenderY - o.getY()) / o.getHeight())
                        }
                    } else {
                        var o = this.component.grid;
                        o && this._zr.trigger("mousemove", {connectTrigger: !0,zrenderX: o.getX() + e.x * o.getWidth(),zrenderY: o.getY() + e.y * o.getHeight()})
                    }
            }
            if (this._connected && t && this._curEventType === e.type) {
                for (var r in this._connected)
                    this._connected[r].connectedEventHandler(e);
                this._curEventType = null
            }
            (!t || !this._connected && t) && (this._curEventType = null)
        },_onclick: function(e) {
            if (n(this, "onclick", e), e.target) {
                var t = this._eventPackage(e.target);
                t && null != t.seriesIndex && this._messageCenter.dispatch(a.EVENT.CLICK, e.event, t, this)
            }
        },_ondblclick: function(e) {
            if (n(this, "ondblclick", e), e.target) {
                var t = this._eventPackage(e.target);
                t && null != t.seriesIndex && this._messageCenter.dispatch(a.EVENT.DBLCLICK, e.event, t, this)
            }
        },_onmouseover: function(e) {
            if (e.target) {
                var t = this._eventPackage(e.target);
                t && null != t.seriesIndex && this._messageCenter.dispatch(a.EVENT.HOVER, e.event, t, this)
            }
        },_onmouseout: function(e) {
            if (e.target) {
                var t = this._eventPackage(e.target);
                t && null != t.seriesIndex && this._messageCenter.dispatch(a.EVENT.MOUSEOUT, e.event, t, this)
            }
        },_ondragstart: function(e) {
            this._status = {dragIn: !1,dragOut: !1,needRefresh: !1}, n(this, "ondragstart", e)
        },_ondragenter: function(e) {
            n(this, "ondragenter", e)
        },_ondragover: function(e) {
            n(this, "ondragover", e)
        },_ondragleave: function(e) {
            n(this, "ondragleave", e)
        },_ondrop: function(e) {
            n(this, "ondrop", e, this._status), this._island.ondrop(e, this._status)
        },_ondragend: function(e) {
            if (n(this, "ondragend", e, this._status), this._timeline && this._timeline.ondragend(e, this._status), this._island.ondragend(e, this._status), this._status.needRefresh) {
                this._syncBackupData(this._option);
                var t = this._messageCenter;
                t.dispatch(a.EVENT.DATA_CHANGED, e.event, this._eventPackage(e.target), this), t.dispatch(a.EVENT.REFRESH, null, null, this)
            }
        },_onlegendSelected: function(e) {
            this._status.needRefresh = !1, n(this, "onlegendSelected", e, this._status), this._status.needRefresh && this._messageCenter.dispatch(a.EVENT.REFRESH, null, null, this)
        },_ondataZoom: function(e) {
            this._status.needRefresh = !1, n(this, "ondataZoom", e, this._status), this._status.needRefresh && this._messageCenter.dispatch(a.EVENT.REFRESH, null, null, this)
        },_ondataRange: function(e) {
            this._clearEffect(), this._status.needRefresh = !1, n(this, "ondataRange", e, this._status), this._status.needRefresh && this._zr.refreshNextFrame()
        },_onmagicTypeChanged: function() {
            this._clearEffect(), this._render(this._toolbox.getMagicOption())
        },_ondataViewChanged: function(e) {
            this._syncBackupData(e.option), this._messageCenter.dispatch(a.EVENT.DATA_CHANGED, null, e, this), this._messageCenter.dispatch(a.EVENT.REFRESH, null, null, this)
        },_tooltipHover: function(e) {
            var t = [];
            n(this, "ontooltipHover", e, t)
        },_onrestore: function() {
            this.restore()
        },_onrefresh: function(e) {
            this._refreshInside = !0, this.refresh(e), this._refreshInside = !1
        },_syncBackupData: function(e) {
            this.component.dataZoom && this.component.dataZoom.syncBackupData(e)
        },_eventPackage: function(t) {
            if (t) {
                var i = e("./util/ecData"), n = i.get(t, "seriesIndex"), a = i.get(t, "dataIndex");
                return a = -1 != n && this.component.dataZoom ? this.component.dataZoom.getRealDataIndex(n, a) : a, {seriesIndex: n,seriesName: (i.get(t, "series") || {}).name,dataIndex: a,data: i.get(t, "data"),name: i.get(t, "name"),value: i.get(t, "value"),special: i.get(t, "special")}
            }
        },_noDataCheck: function(e) {
            for (var t = e.series, i = 0, n = t.length; n > i; i++)
                if (t[i].type == a.CHART_TYPE_MAP || t[i].data && t[i].data.length > 0 || t[i].markPoint && t[i].markPoint.data && t[i].markPoint.data.length > 0 || t[i].markLine && t[i].markLine.data && t[i].markLine.data.length > 0 || t[i].nodes && t[i].nodes.length > 0 || t[i].links && t[i].links.length > 0 || t[i].matrix && t[i].matrix.length > 0 || t[i].eventList && t[i].eventList.length > 0)
                    return !1;
            var o = this._option && this._option.noDataLoadingOption || this._themeConfig.noDataLoadingOption || a.noDataLoadingOption || {text: this._option && this._option.noDataText || this._themeConfig.noDataText || a.noDataText,effect: this._option && this._option.noDataEffect || this._themeConfig.noDataEffect || a.noDataEffect};
            return this.clear(), this.showLoading(o), !0
        },_render: function(t) {
            if (this._mergeGlobalConifg(t), !this._noDataCheck(t)) {
                var i = t.backgroundColor;
                if (i)
                    if (l || -1 == i.indexOf("rgba"))
                        this.dom.style.backgroundColor = i;
                    else {
                        var n = i.split(",");
                        this.dom.style.filter = "alpha(opacity=" + 100 * n[3].substring(0, n[3].lastIndexOf(")")) + ")", n.length = 3, n[0] = n[0].replace("a", ""), this.dom.style.backgroundColor = n.join(",") + ")"
                    }
                this._zr.clearAnimation(), this._chartList = [];
                var o = e("./chart"), r = e("./component");
                (t.xAxis || t.yAxis) && (t.grid = t.grid || {}, t.dataZoom = t.dataZoom || {});
                for (var s, h, d, c = ["title", "legend", "tooltip", "dataRange", "roamController", "grid", "dataZoom", "xAxis", "yAxis", "polar"], m = 0, p = c.length; p > m; m++)
                    h = c[m], d = this.component[h], t[h] ? (d ? d.refresh && d.refresh(t) : (s = r.get(/^[xy]Axis$/.test(h) ? "axis" : h), d = new s(this._themeConfig, this._messageCenter, this._zr, t, this, h), this.component[h] = d), this._chartList.push(d)) : d && (d.dispose(), this.component[h] = null, delete this.component[h]);
                for (var u, V, U, g = {}, m = 0, p = t.series.length; p > m; m++)
                    V = t.series[m].type, V ? g[V] || (g[V] = !0, u = o.get(V), u ? (this.chart[V] ? (U = this.chart[V], U.refresh(t)) : U = new u(this._themeConfig, this._messageCenter, this._zr, t, this), this._chartList.push(U), this.chart[V] = U) : console.error(V + " has not been required.")) : console.error("series[" + m + "] chart type has not been defined.");
                for (V in this.chart)
                    V == a.CHART_TYPE_ISLAND || g[V] || (this.chart[V].dispose(), this.chart[V] = null, delete this.chart[V]);
                this.component.grid && this.component.grid.refixAxisShape(this.component), this._island.refresh(t), this._toolbox.refresh(t), t.animation && !t.renderAsImage ? this._zr.refresh() : this._zr.render();
                var f = "IMG" + this.id, y = document.getElementById(f);
                t.renderAsImage && l ? (y ? y.src = this.getDataURL(t.renderAsImage) : (y = this.getImage(t.renderAsImage), y.id = f, y.style.position = "absolute", y.style.left = 0, y.style.top = 0, this.dom.firstChild.appendChild(y)), this.un(), this._zr.un(), this._disposeChartList(), this._zr.clear()) : y && y.parentNode.removeChild(y), y = null, this._option = t
            }
        },restore: function() {
            this._clearEffect(), this._option = o.clone(this._optionRestore), this._disposeChartList(), this._island.clear(), this._toolbox.reset(this._option, !0), this._render(this._option)
        },refresh: function(e) {
            this._clearEffect(), e = e || {};
            var t = e.option;
            !this._refreshInside && t && (t = this.getOption(), o.merge(t, e.option, !0), o.merge(this._optionRestore, e.option, !0), this._toolbox.reset(t)), this._island.refresh(t), this._toolbox.refresh(t), this._zr.clearAnimation();
            for (var i = 0, n = this._chartList.length; n > i; i++)
                this._chartList[i].refresh && this._chartList[i].refresh(t);
            this.component.grid && this.component.grid.refixAxisShape(this.component), this._zr.refresh()
        },_disposeChartList: function() {
            this._clearEffect(), this._zr.clearAnimation();
            for (var e = this._chartList.length; e--; ) {
                var t = this._chartList[e];
                if (t) {
                    var i = t.type;
                    this.chart[i] && delete this.chart[i], this.component[i] && delete this.component[i], t.dispose && t.dispose()
                }
            }
            this._chartList = []
        },_mergeGlobalConifg: function(t) {
            for (var i = ["backgroundColor", "calculable", "calculableColor", "calculableHolderColor", "nameConnector", "valueConnector", "animation", "animationThreshold", "animationDuration", "animationDurationUpdate", "animationEasing", "addDataAnimation", "symbolList", "DRAG_ENABLE_TIME"], n = i.length; n--; ) {
                var o = i[n];
                null == t[o] && (t[o] = null != this._themeConfig[o] ? this._themeConfig[o] : a[o])
            }
            var r = t.color;
            r && r.length || (r = this._themeConfig.color || a.color), this._zr.getColor = function(t) {
                var i = e("zrender/tool/color");
                return i.getColor(t, r)
            }, l || (t.animation = !1, t.addDataAnimation = !1)
        },setOption: function(e, t) {
            return e.timeline ? this._setTimelineOption(e) : this._setOption(e, t)
        },_setOption: function(e, t, i) {
            return !t && this._option ? this._option = o.merge(this.getOption(), o.clone(e), !0) : (this._option = o.clone(e), !i && this._timeline && this._timeline.dispose()), this._optionRestore = o.clone(this._option), this._option.series && 0 !== this._option.series.length ? (this.component.dataZoom && (this._option.dataZoom || this._option.toolbox && this._option.toolbox.feature && this._option.toolbox.feature.dataZoom && this._option.toolbox.feature.dataZoom.show) && this.component.dataZoom.syncOption(this._option), this._toolbox.reset(this._option), this._render(this._option), this) : void this._zr.clear()
        },getOption: function() {
            function e(e) {
                var n = i._optionRestore[e];
                if (n)
                    if (n instanceof Array)
                        for (var a = n.length; a--; )
                            t[e][a].data = o.clone(n[a].data);
                    else
                        t[e].data = o.clone(n.data)
            }
            var t = o.clone(this._option), i = this;
            return e("xAxis"), e("yAxis"), e("series"), t
        },setSeries: function(e, t) {
            return t ? (this._option.series = e, this.setOption(this._option, t)) : this.setOption({series: e}), this
        },getSeries: function() {
            return this.getOption().series
        },_setTimelineOption: function(t) {
            this._timeline && this._timeline.dispose();
            var i = e("./component/timeline"), n = new i(this._themeConfig, this._messageCenter, this._zr, t, this);
            return this._timeline = n, this.component.timeline = this._timeline, this
        },addData: function(e, t, i, n, r) {
            function s() {
                if (c._zr) {
                    c._zr.clearAnimation();
                    for (var e = 0, t = w.length; t > e; e++)
                        w[e].motionlessOnce = h.addDataAnimation && w[e].addDataAnimation;
                    c._messageCenter.dispatch(a.EVENT.REFRESH, null, {option: h}, c)
                }
            }
            for (var l = e instanceof Array ? e : [[e, t, i, n, r]], h = this.getOption(), d = this._optionRestore, c = this, m = 0, p = l.length; p > m; m++) {
                e = l[m][0], t = l[m][1], i = l[m][2], n = l[m][3], r = l[m][4];
                var u = d.series[e], V = i ? "unshift" : "push", U = i ? "pop" : "shift";
                if (u) {
                    var g = u.data, f = h.series[e].data;
                    if (g[V](t), f[V](t), n || (g[U](), t = f[U]()), null != r) {
                        var y, b;
                        if (u.type === a.CHART_TYPE_PIE && (y = d.legend) && (b = y.data)) {
                            var _ = h.legend.data;
                            if (b[V](r), _[V](r), !n) {
                                var x = o.indexOf(b, t.name);
                                -1 != x && b.splice(x, 1), x = o.indexOf(_, t.name), -1 != x && _.splice(x, 1)
                            }
                        } else if (null != d.xAxis && null != d.yAxis) {
                            var k, v, L = u.xAxisIndex || 0;
                            (null == d.xAxis[L].type || "category" === d.xAxis[L].type) && (k = d.xAxis[L].data, v = h.xAxis[L].data, k[V](r), v[V](r), n || (k[U](), v[U]())), L = u.yAxisIndex || 0, "category" === d.yAxis[L].type && (k = d.yAxis[L].data, v = h.yAxis[L].data, k[V](r), v[V](r), n || (k[U](), v[U]()))
                        }
                    }
                    this._option.series[e].data = h.series[e].data
                }
            }
            this._zr.clearAnimation();
            for (var w = this._chartList, W = 0, X = function() {
                W--, 0 === W && s()
            }, m = 0, p = w.length; p > m; m++)
                h.addDataAnimation && w[m].addDataAnimation && (W++, w[m].addDataAnimation(l, X));
            return this.component.dataZoom && this.component.dataZoom.syncOption(h), this._option = h, h.addDataAnimation || setTimeout(s, 0), this
        },addMarkPoint: function(e, t) {
            return this._addMark(e, t, "markPoint")
        },addMarkLine: function(e, t) {
            return this._addMark(e, t, "markLine")
        },_addMark: function(e, t, i) {
            var n, a = this._option.series;
            if (a && (n = a[e])) {
                var r = this._optionRestore.series, s = r[e], l = n[i], h = s[i];
                l = n[i] = l || {data: []}, h = s[i] = h || {data: []};
                for (var d in t)
                    "data" === d ? (l.data = l.data.concat(t.data), h.data = h.data.concat(t.data)) : "object" != typeof t[d] || null == l[d] ? l[d] = h[d] = t[d] : (o.merge(l[d], t[d], !0), o.merge(h[d], t[d], !0));
                var c = this.chart[n.type];
                c && c.addMark(e, t, i)
            }
            return this
        },delMarkPoint: function(e, t) {
            return this._delMark(e, t, "markPoint")
        },delMarkLine: function(e, t) {
            return this._delMark(e, t, "markLine")
        },_delMark: function(e, t, i) {
            var n, a, o, r = this._option.series;
            if (!(r && (n = r[e]) && (a = n[i]) && (o = a.data)))
                return this;
            t = t.split(" > ");
            for (var s = -1, l = 0, h = o.length; h > l; l++) {
                var d = o[l];
                if (d instanceof Array) {
                    if (d[0].name === t[0] && d[1].name === t[1]) {
                        s = l;
                        break
                    }
                } else if (d.name === t[0]) {
                    s = l;
                    break
                }
            }
            if (s > -1) {
                o.splice(s, 1), this._optionRestore.series[e][i].data.splice(s, 1);
                var c = this.chart[n.type];
                c && c.delMark(e, t.join(" > "), i)
            }
            return this
        },getDom: function() {
            return this.dom
        },getZrender: function() {
            return this._zr
        },getDataURL: function(e) {
            if (!l)
                return "";
            if (0 === this._chartList.length) {
                var t = "IMG" + this.id, i = document.getElementById(t);
                if (i)
                    return i.src
            }
            var n = this.component.tooltip;
            switch (n && n.hideTip(), e) {
                case "jpeg":
                    break;
                default:
                    e = "png"
            }
            var a = this._option.backgroundColor;
            return a && "rgba(0,0,0,0)" === a.replace(" ", "") && (a = "#fff"), this._zr.toDataURL("image/" + e, a)
        },getImage: function(e) {
            var t = this._optionRestore.title, i = document.createElement("img");
            return i.src = this.getDataURL(e), i.title = t && t.text || "ECharts", i
        },getConnectedDataURL: function(t) {
            if (!this.isConnected())
                return this.getDataURL(t);
            var i = this.dom, n = {self: {img: this.getDataURL(t),left: i.offsetLeft,top: i.offsetTop,right: i.offsetLeft + i.offsetWidth,bottom: i.offsetTop + i.offsetHeight}}, a = n.self.left, o = n.self.top, r = n.self.right, s = n.self.bottom;
            for (var l in this._connected)
                i = this._connected[l].getDom(), n[l] = {img: this._connected[l].getDataURL(t),left: i.offsetLeft,top: i.offsetTop,right: i.offsetLeft + i.offsetWidth,bottom: i.offsetTop + i.offsetHeight}, a = Math.min(a, n[l].left), o = Math.min(o, n[l].top), r = Math.max(r, n[l].right), s = Math.max(s, n[l].bottom);
            var h = document.createElement("div");
            h.style.position = "absolute", h.style.left = "-4000px", h.style.width = r - a + "px", h.style.height = s - o + "px", document.body.appendChild(h);
            var d = e("zrender").init(h), c = e("zrender/shape/Image");
            for (var l in n)
                d.addShape(new c({style: {x: n[l].left - a,y: n[l].top - o,image: n[l].img}}));
            d.render();
            var m = this._option.backgroundColor;
            m && "rgba(0,0,0,0)" === m.replace(/ /g, "") && (m = "#fff");
            var p = d.toDataURL("image/png", m);
            return setTimeout(function() {
                d.dispose(), h.parentNode.removeChild(h), h = null
            }, 100), p
        },getConnectedImage: function(e) {
            var t = this._optionRestore.title, i = document.createElement("img");
            return i.src = this.getConnectedDataURL(e), i.title = t && t.text || "ECharts", i
        },on: function(e, t) {
            return this._messageCenterOutSide.bind(e, t, this), this
        },un: function(e, t) {
            return this._messageCenterOutSide.unbind(e, t), this
        },connect: function(e) {
            if (!e)
                return this;
            if (this._connected || (this._connected = {}), e instanceof Array)
                for (var t = 0, i = e.length; i > t; t++)
                    this._connected[e[t].id] = e[t];
            else
                this._connected[e.id] = e;
            return this
        },disConnect: function(e) {
            if (!e || !this._connected)
                return this;
            if (e instanceof Array)
                for (var t = 0, i = e.length; i > t; t++)
                    delete this._connected[e[t].id];
            else
                delete this._connected[e.id];
            for (var n in this._connected)
                return this;
            return this._connected = !1, this
        },connectedEventHandler: function(e) {
            e.__echartsId != this.id && this._onevent(e)
        },isConnected: function() {
            return !!this._connected
        },showLoading: function(t) {
            var i = {bar: e("zrender/loadingEffect/Bar"),bubble: e("zrender/loadingEffect/Bubble"),dynamicLine: e("zrender/loadingEffect/DynamicLine"),ring: e("zrender/loadingEffect/Ring"),spin: e("zrender/loadingEffect/Spin"),whirling: e("zrender/loadingEffect/Whirling")};
            this._toolbox.hideDataView(), t = t || {};
            var n = t.textStyle || {};
            t.textStyle = n;
            var r = o.merge(o.merge(o.clone(n), this._themeConfig.textStyle), a.textStyle);
            n.textFont = r.fontStyle + " " + r.fontWeight + " " + r.fontSize + "px " + r.fontFamily, n.text = t.text || this._option && this._option.loadingText || this._themeConfig.loadingText || a.loadingText, null != t.x && (n.x = t.x), null != t.y && (n.y = t.y), t.effectOption = t.effectOption || {}, t.effectOption.textStyle = n;
            var s = t.effect;
            return ("string" == typeof s || null == s) && (s = i[t.effect || this._option && this._option.loadingEffect || this._themeConfig.loadingEffect || a.loadingEffect] || i.spin), this._zr.showLoading(new s(t.effectOption)), this
        },hideLoading: function() {
            return this._zr.hideLoading(), this
        },setTheme: function(t) {
            if (t) {
                if ("string" == typeof t)
                    switch (t) {
                        case "macarons":
                            t = e("./theme/macarons");
                            break;
                        case "infographic":
                            t = e("./theme/infographic");
                            break;
                        default:
                            t = {}
                    }
                else
                    t = t || {};
                this._themeConfig = t
            }
            if (!l) {
                var i = this._themeConfig.textStyle;
                i && i.fontFamily && i.fontFamily2 && (i.fontFamily = i.fontFamily2), i = a.textStyle, i.fontFamily = i.fontFamily2
            }
            this._timeline && this._timeline.setTheme(!0), this._optionRestore && this.restore()
        },resize: function() {
            var e = this;
            return function() {
                if (e._clearEffect(), e._zr.resize(), e._option && e._option.renderAsImage && l)
                    return e._render(e._option), e;
                e._zr.clearAnimation(), e._island.resize(), e._toolbox.resize(), e._timeline && e._timeline.resize();
                for (var t = 0, i = e._chartList.length; i > t; t++)
                    e._chartList[t].resize && e._chartList[t].resize();
                return e.component.grid && e.component.grid.refixAxisShape(e.component), e._zr.refresh(), e._messageCenter.dispatch(a.EVENT.RESIZE, null, null, e), e
            }
        },_clearEffect: function() {
            this._zr.modLayer(a.EFFECT_ZLEVEL, {motionBlur: !1}), this._zr.painter.clearLayer(a.EFFECT_ZLEVEL)
        },clear: function() {
            return this._disposeChartList(), this._zr.clear(), this._option = {}, this._optionRestore = {}, this.dom.style.backgroundColor = null, this
        },dispose: function() {
            var e = this.dom.getAttribute(c);
            e && delete d[e], this._island.dispose(), this._toolbox.dispose(), this._timeline && this._timeline.dispose(), this._messageCenter.unbind(), this.clear(), this._zr.dispose(), this._zr = null
        }}, s
}), define("echarts/config", [], function() {
    var e = {CHART_TYPE_LINE: "line",CHART_TYPE_BAR: "bar",CHART_TYPE_SCATTER: "scatter",CHART_TYPE_PIE: "pie",CHART_TYPE_RADAR: "radar",CHART_TYPE_VENN: "venn",CHART_TYPE_TREEMAP: "treemap",CHART_TYPE_TREE: "tree",CHART_TYPE_MAP: "map",CHART_TYPE_K: "k",CHART_TYPE_ISLAND: "island",CHART_TYPE_FORCE: "force",CHART_TYPE_CHORD: "chord",CHART_TYPE_GAUGE: "gauge",CHART_TYPE_FUNNEL: "funnel",CHART_TYPE_EVENTRIVER: "eventRiver",CHART_TYPE_WORDCLOUD: "wordCloud",CHART_TYPE_HEATMAP: "heatmap",COMPONENT_TYPE_TITLE: "title",COMPONENT_TYPE_LEGEND: "legend",COMPONENT_TYPE_DATARANGE: "dataRange",COMPONENT_TYPE_DATAVIEW: "dataView",COMPONENT_TYPE_DATAZOOM: "dataZoom",COMPONENT_TYPE_TOOLBOX: "toolbox",COMPONENT_TYPE_TOOLTIP: "tooltip",COMPONENT_TYPE_GRID: "grid",COMPONENT_TYPE_AXIS: "axis",COMPONENT_TYPE_POLAR: "polar",COMPONENT_TYPE_X_AXIS: "xAxis",COMPONENT_TYPE_Y_AXIS: "yAxis",COMPONENT_TYPE_AXIS_CATEGORY: "categoryAxis",COMPONENT_TYPE_AXIS_VALUE: "valueAxis",COMPONENT_TYPE_TIMELINE: "timeline",COMPONENT_TYPE_ROAMCONTROLLER: "roamController",backgroundColor: "rgba(0,0,0,0)",color: ["#ff7f50", "#87cefa", "#da70d6", "#32cd32", "#6495ed", "#ff69b4", "#ba55d3", "#cd5c5c", "#ffa500", "#40e0d0", "#1e90ff", "#ff6347", "#7b68ee", "#00fa9a", "#ffd700", "#6699FF", "#ff6666", "#3cb371", "#b8860b", "#30e0e0"],markPoint: {clickable: !0,symbol: "pin",symbolSize: 10,large: !1,effect: {show: !1,loop: !0,period: 15,type: "scale",scaleSize: 2,bounceDistance: 10},itemStyle: {normal: {borderWidth: 2,label: {show: !0,position: "inside"}},emphasis: {label: {show: !0}}}},markLine: {clickable: !0,symbol: ["circle", "arrow"],symbolSize: [2, 4],smoothness: .2,precision: 2,effect: {show: !1,loop: !0,period: 15,scaleSize: 2},bundling: {enable: !1,maxTurningAngle: 45},itemStyle: {normal: {borderWidth: 1.5,label: {show: !0,position: "end"},lineStyle: {type: "dashed"}},emphasis: {label: {show: !1},lineStyle: {}}}},textStyle: {decoration: "none",fontFamily: "Arial, Verdana, sans-serif",fontFamily2: "微软雅黑",fontSize: 12,fontStyle: "normal",fontWeight: "normal"},EVENT: {REFRESH: "refresh",RESTORE: "restore",RESIZE: "resize",CLICK: "click",DBLCLICK: "dblclick",HOVER: "hover",MOUSEOUT: "mouseout",DATA_CHANGED: "dataChanged",DATA_ZOOM: "dataZoom",DATA_RANGE: "dataRange",DATA_RANGE_SELECTED: "dataRangeSelected",DATA_RANGE_HOVERLINK: "dataRangeHoverLink",LEGEND_SELECTED: "legendSelected",LEGEND_HOVERLINK: "legendHoverLink",MAP_SELECTED: "mapSelected",PIE_SELECTED: "pieSelected",MAGIC_TYPE_CHANGED: "magicTypeChanged",DATA_VIEW_CHANGED: "dataViewChanged",TIMELINE_CHANGED: "timelineChanged",MAP_ROAM: "mapRoam",FORCE_LAYOUT_END: "forceLayoutEnd",TOOLTIP_HOVER: "tooltipHover",TOOLTIP_IN_GRID: "tooltipInGrid",TOOLTIP_OUT_GRID: "tooltipOutGrid",ROAMCONTROLLER: "roamController"},DRAG_ENABLE_TIME: 120,EFFECT_ZLEVEL: 10,effectBlendAlpha: .95,symbolList: ["circle", "rectangle", "triangle", "diamond", "emptyCircle", "emptyRectangle", "emptyTriangle", "emptyDiamond"],loadingEffect: "spin",loadingText: "数据读取中...",noDataEffect: "bubble",noDataText: "暂无数据",calculable: !1,calculableColor: "rgba(255,165,0,0.6)",calculableHolderColor: "#ccc",nameConnector: " & ",valueConnector: ": ",animation: !0,addDataAnimation: !0,animationThreshold: 2e3,animationDuration: 2e3,animationDurationUpdate: 500,animationEasing: "ExponentialOut"};
    return e
}), define("zrender/tool/util", ["require", "../dep/excanvas"], function(e) {
    function t(e) {
        return e && 1 === e.nodeType && "string" == typeof e.nodeName
    }
    function i(e) {
        if ("object" == typeof e && null !== e) {
            var n = e;
            if (e instanceof Array) {
                n = [];
                for (var a = 0, o = e.length; o > a; a++)
                    n[a] = i(e[a])
            } else if (!g[f.call(e)] && !t(e)) {
                n = {};
                for (var r in e)
                    e.hasOwnProperty(r) && (n[r] = i(e[r]))
            }
            return n
        }
        return e
    }
    function n(e, i, n, o) {
        if (i.hasOwnProperty(n)) {
            var r = e[n];
            "object" != typeof r || g[f.call(r)] || t(r) ? !o && n in e || (e[n] = i[n]) : a(e[n], i[n], o)
        }
    }
    function a(e, t, i) {
        for (var a in t)
            n(e, t, a, i);
        return e
    }
    function o() {
        if (!m)
            if (e("../dep/excanvas"), window.G_vmlCanvasManager) {
                var t = document.createElement("div");
                t.style.position = "absolute", t.style.top = "-1000px", document.body.appendChild(t), m = G_vmlCanvasManager.initElement(t).getContext("2d");
            
            } else
                m = document.createElement("canvas").getContext("2d");
        return m
    }
    function r(e, t) {
        if (e.indexOf)
            return e.indexOf(t);
        for (var i = 0, n = e.length; n > i; i++)
            if (e[i] === t)
                return i;
        return -1
    }
    function s(e, t) {
        function i() {
        }
        var n = e.prototype;
        i.prototype = t.prototype, e.prototype = new i;
        for (var a in n)
            e.prototype[a] = n[a];
        e.constructor = e
    }
    function l(e, t, i) {
        if (e && t)
            if (e.forEach && e.forEach === u)
                e.forEach(t, i);
            else if (e.length === +e.length)
                for (var n = 0, a = e.length; a > n; n++)
                    t.call(i, e[n], n, e);
            else
                for (var o in e)
                    e.hasOwnProperty(o) && t.call(i, e[o], o, e)
    }
    function h(e, t, i) {
        if (e && t) {
            if (e.map && e.map === V)
                return e.map(t, i);
            for (var n = [], a = 0, o = e.length; o > a; a++)
                n.push(t.call(i, e[a], a, e));
            return n
        }
    }
    function d(e, t, i) {
        if (e && t) {
            if (e.filter && e.filter === U)
                return e.filter(t, i);
            for (var n = [], a = 0, o = e.length; o > a; a++)
                t.call(i, e[a], a, e) && n.push(e[a]);
            return n
        }
    }
    function c(e, t) {
        return function() {
            e.apply(t, arguments)
        }
    }
    var m, p = Array.prototype, u = p.forEach, V = p.map, U = p.filter, g = {"[object Function]": 1,"[object RegExp]": 1,"[object Date]": 1,"[object Error]": 1,"[object CanvasGradient]": 1}, f = Object.prototype.toString;
    return {inherits: s,clone: i,merge: a,getContext: o,indexOf: r,each: l,map: h,filter: d,bind: c}
}), define("zrender/tool/event", ["require", "../mixin/Eventful"], function(e) {
    "use strict";
    function t(e) {
        return "undefined" != typeof e.zrenderX && e.zrenderX || "undefined" != typeof e.offsetX && e.offsetX || "undefined" != typeof e.layerX && e.layerX || "undefined" != typeof e.clientX && e.clientX
    }
    function i(e) {
        return "undefined" != typeof e.zrenderY && e.zrenderY || "undefined" != typeof e.offsetY && e.offsetY || "undefined" != typeof e.layerY && e.layerY || "undefined" != typeof e.clientY && e.clientY
    }
    function n(e) {
        return "undefined" != typeof e.zrenderDelta && e.zrenderDelta || "undefined" != typeof e.wheelDelta && e.wheelDelta || "undefined" != typeof e.detail && -e.detail
    }
    var a = e("../mixin/Eventful"), o = "function" == typeof window.addEventListener ? function(e) {
        e.preventDefault(), e.stopPropagation(), e.cancelBubble = !0
    } : function(e) {
        e.returnValue = !1, e.cancelBubble = !0
    };
    return {getX: t,getY: i,getDelta: n,stop: o,Dispatcher: a}
}), define("zrender/tool/env", [], function() {
    function e(e) {
        var t = this.os = {}, i = this.browser = {}, n = e.match(/Web[kK]it[\/]{0,1}([\d.]+)/), a = e.match(/(Android);?[\s\/]+([\d.]+)?/), o = e.match(/(iPad).*OS\s([\d_]+)/), r = e.match(/(iPod)(.*OS\s([\d_]+))?/), s = !o && e.match(/(iPhone\sOS)\s([\d_]+)/), l = e.match(/(webOS|hpwOS)[\s\/]([\d.]+)/), h = l && e.match(/TouchPad/), d = e.match(/Kindle\/([\d.]+)/), c = e.match(/Silk\/([\d._]+)/), m = e.match(/(BlackBerry).*Version\/([\d.]+)/), p = e.match(/(BB10).*Version\/([\d.]+)/), u = e.match(/(RIM\sTablet\sOS)\s([\d.]+)/), V = e.match(/PlayBook/), U = e.match(/Chrome\/([\d.]+)/) || e.match(/CriOS\/([\d.]+)/), g = e.match(/Firefox\/([\d.]+)/), f = e.match(/MSIE ([\d.]+)/), y = n && e.match(/Mobile\//) && !U, b = e.match(/(iPhone|iPod|iPad).*AppleWebKit(?!.*Safari)/) && !U, f = e.match(/MSIE\s([\d.]+)/);
        return (i.webkit = !!n) && (i.version = n[1]), a && (t.android = !0, t.version = a[2]), s && !r && (t.ios = t.iphone = !0, t.version = s[2].replace(/_/g, ".")), o && (t.ios = t.ipad = !0, t.version = o[2].replace(/_/g, ".")), r && (t.ios = t.ipod = !0, t.version = r[3] ? r[3].replace(/_/g, ".") : null), l && (t.webos = !0, t.version = l[2]), h && (t.touchpad = !0), m && (t.blackberry = !0, t.version = m[2]), p && (t.bb10 = !0, t.version = p[2]), u && (t.rimtabletos = !0, t.version = u[2]), V && (i.playbook = !0), d && (t.kindle = !0, t.version = d[1]), c && (i.silk = !0, i.version = c[1]), !c && t.android && e.match(/Kindle Fire/) && (i.silk = !0), U && (i.chrome = !0, i.version = U[1]), g && (i.firefox = !0, i.version = g[1]), f && (i.ie = !0, i.version = f[1]), y && (e.match(/Safari/) || t.ios) && (i.safari = !0), b && (i.webview = !0), f && (i.ie = !0, i.version = f[1]), t.tablet = !!(o || V || a && !e.match(/Mobile/) || g && e.match(/Tablet/) || f && !e.match(/Phone/) && e.match(/Touch/)), t.phone = !(t.tablet || t.ipod || !(a || s || l || m || p || U && e.match(/Android/) || U && e.match(/CriOS\/([\d.]+)/) || g && e.match(/Mobile/) || f && e.match(/Touch/))), {browser: i,os: t,canvasSupported: document.createElement("canvas").getContext ? !0 : !1}
    }
    return e(navigator.userAgent)
}), define("zrender", ["zrender/zrender"], function(e) {
    return e
}), define("zrender/zrender", ["require", "./dep/excanvas", "./tool/util", "./tool/log", "./tool/guid", "./Handler", "./Painter", "./Storage", "./animation/Animation", "./tool/env"], function(e) {
    function t(e) {
        return function() {
            e._needsRefreshNextFrame && e.refresh()
        }
    }
    e("./dep/excanvas");
    var i = e("./tool/util"), n = e("./tool/log"), a = e("./tool/guid"), o = e("./Handler"), r = e("./Painter"), s = e("./Storage"), l = e("./animation/Animation"), h = {}, d = {};
    d.version = "2.1.1", d.init = function(e) {
        var t = new c(a(), e);
        return h[t.id] = t, t
    }, d.dispose = function(e) {
        if (e)
            e.dispose();
        else {
            for (var t in h)
                h[t].dispose();
            h = {}
        }
        return d
    }, d.getInstance = function(e) {
        return h[e]
    }, d.delInstance = function(e) {
        return delete h[e], d
    };
    var c = function(i, n) {
        this.id = i, this.env = e("./tool/env"), this.storage = new s, this.painter = new r(n, this.storage), this.handler = new o(n, this.storage, this.painter), this.animation = new l({stage: {update: t(this)}}), this.animation.start();
        var a = this;
        this.painter.refreshNextFrame = function() {
            a.refreshNextFrame()
        }, this._needsRefreshNextFrame = !1;
        var a = this, h = this.storage, d = h.delFromMap;
        h.delFromMap = function(e) {
            var t = h.get(e);
            a.stopAnimation(t), d.call(h, e)
        }
    };
    return c.prototype.getId = function() {
        return this.id
    }, c.prototype.addShape = function(e) {
        return this.addElement(e), this
    }, c.prototype.addGroup = function(e) {
        return this.addElement(e), this
    }, c.prototype.delShape = function(e) {
        return this.delElement(e), this
    }, c.prototype.delGroup = function(e) {
        return this.delElement(e), this
    }, c.prototype.modShape = function(e, t) {
        return this.modElement(e, t), this
    }, c.prototype.modGroup = function(e, t) {
        return this.modElement(e, t), this
    }, c.prototype.addElement = function(e) {
        return this.storage.addRoot(e), this._needsRefreshNextFrame = !0, this
    }, c.prototype.delElement = function(e) {
        return this.storage.delRoot(e), this._needsRefreshNextFrame = !0, this
    }, c.prototype.modElement = function(e, t) {
        return this.storage.mod(e, t), this._needsRefreshNextFrame = !0, this
    }, c.prototype.modLayer = function(e, t) {
        return this.painter.modLayer(e, t), this._needsRefreshNextFrame = !0, this
    }, c.prototype.addHoverShape = function(e) {
        return this.storage.addHover(e), this
    }, c.prototype.render = function(e) {
        return this.painter.render(e), this._needsRefreshNextFrame = !1, this
    }, c.prototype.refresh = function(e) {
        return this.painter.refresh(e), this._needsRefreshNextFrame = !1, this
    }, c.prototype.refreshNextFrame = function() {
        return this._needsRefreshNextFrame = !0, this
    }, c.prototype.refreshHover = function(e) {
        return this.painter.refreshHover(e), this
    }, c.prototype.refreshShapes = function(e, t) {
        return this.painter.refreshShapes(e, t), this
    }, c.prototype.resize = function() {
        return this.painter.resize(), this
    }, c.prototype.animate = function(e, t, a) {
        var o = this;
        if ("string" == typeof e && (e = this.storage.get(e)), e) {
            var r;
            if (t) {
                for (var s = t.split("."), l = e, h = 0, d = s.length; d > h; h++)
                    l && (l = l[s[h]]);
                l && (r = l)
            } else
                r = e;
            if (!r)
                return void n('Property "' + t + '" is not existed in element ' + e.id);
            null == e.__animators && (e.__animators = []);
            var c = e.__animators, m = this.animation.animate(r, {loop: a}).during(function() {
                o.modShape(e)
            }).done(function() {
                var t = i.indexOf(e.__animators, m);
                t >= 0 && c.splice(t, 1)
            });
            return c.push(m), m
        }
        n("Element not existed")
    }, c.prototype.stopAnimation = function(e) {
        if (e.__animators) {
            for (var t = e.__animators, i = t.length, n = 0; i > n; n++)
                t[n].stop();
            t.length = 0
        }
        return this
    }, c.prototype.clearAnimation = function() {
        return this.animation.clear(), this
    }, c.prototype.showLoading = function(e) {
        return this.painter.showLoading(e), this
    }, c.prototype.hideLoading = function() {
        return this.painter.hideLoading(), this
    }, c.prototype.getWidth = function() {
        return this.painter.getWidth()
    }, c.prototype.getHeight = function() {
        return this.painter.getHeight()
    }, c.prototype.toDataURL = function(e, t, i) {
        return this.painter.toDataURL(e, t, i)
    }, c.prototype.shapeToImage = function(e, t, i) {
        var n = a();
        return this.painter.shapeToImage(n, e, t, i)
    }, c.prototype.on = function(e, t, i) {
        return this.handler.on(e, t, i), this
    }, c.prototype.un = function(e, t) {
        return this.handler.un(e, t), this
    }, c.prototype.trigger = function(e, t) {
        return this.handler.trigger(e, t), this
    }, c.prototype.clear = function() {
        return this.storage.delRoot(), this.painter.clear(), this
    }, c.prototype.dispose = function() {
        this.animation.stop(), this.clear(), this.storage.dispose(), this.painter.dispose(), this.handler.dispose(), this.animation = this.storage = this.painter = this.handler = null, d.delInstance(this.id)
    }, d
}), define("zrender/config", [], function() {
    var e = {EVENT: {RESIZE: "resize",CLICK: "click",DBLCLICK: "dblclick",MOUSEWHEEL: "mousewheel",MOUSEMOVE: "mousemove",MOUSEOVER: "mouseover",MOUSEOUT: "mouseout",MOUSEDOWN: "mousedown",MOUSEUP: "mouseup",GLOBALOUT: "globalout",DRAGSTART: "dragstart",DRAGEND: "dragend",DRAGENTER: "dragenter",DRAGOVER: "dragover",DRAGLEAVE: "dragleave",DROP: "drop",touchClickDelay: 300},elementClassName: "zr-element",catchBrushException: !1,debugMode: 0,devicePixelRatio: Math.max(window.devicePixelRatio || 1, 1)};
    return e
}), define("echarts/chart/island", ["require", "./base", "zrender/shape/Circle", "../config", "../util/ecData", "zrender/tool/util", "zrender/tool/event", "zrender/tool/color", "../util/accMath", "../chart"], function(e) {
    function t(e, t, n, a, r) {
        i.call(this, e, t, n, a, r), this._nameConnector, this._valueConnector, this._zrHeight = this.zr.getHeight(), this._zrWidth = this.zr.getWidth();
        var l = this;
        l.shapeHandler.onmousewheel = function(e) {
            var t = e.target, i = e.event, n = s.getDelta(i);
            n = n > 0 ? -1 : 1, t.style.r -= n, t.style.r = t.style.r < 5 ? 5 : t.style.r;
            var a = o.get(t, "value"), r = a * l.option.island.calculateStep;
            a = r > 1 ? Math.round(a - r * n) : +(a - r * n).toFixed(2);
            var h = o.get(t, "name");
            t.style.text = h + ":" + a, o.set(t, "value", a), o.set(t, "name", h), l.zr.modShape(t.id), l.zr.refreshNextFrame(), s.stop(i)
        }
    }
    var i = e("./base"), n = e("zrender/shape/Circle"), a = e("../config");
    a.island = {zlevel: 0,z: 5,r: 15,calculateStep: .1};
    var o = e("../util/ecData"), r = e("zrender/tool/util"), s = e("zrender/tool/event");
    return t.prototype = {type: a.CHART_TYPE_ISLAND,_combine: function(t, i) {
            var n = e("zrender/tool/color"), a = e("../util/accMath"), r = a.accAdd(o.get(t, "value"), o.get(i, "value")), s = o.get(t, "name") + this._nameConnector + o.get(i, "name");
            t.style.text = s + this._valueConnector + r, o.set(t, "value", r), o.set(t, "name", s), t.style.r = this.option.island.r, t.style.color = n.mix(t.style.color, i.style.color)
        },refresh: function(e) {
            e && (e.island = this.reformOption(e.island), this.option = e, this._nameConnector = this.option.nameConnector, this._valueConnector = this.option.valueConnector)
        },getOption: function() {
            return this.option
        },resize: function() {
            var e = this.zr.getWidth(), t = this.zr.getHeight(), i = e / (this._zrWidth || e), n = t / (this._zrHeight || t);
            if (1 !== i || 1 !== n) {
                this._zrWidth = e, this._zrHeight = t;
                for (var a = 0, o = this.shapeList.length; o > a; a++)
                    this.zr.modShape(this.shapeList[a].id, {style: {x: Math.round(this.shapeList[a].style.x * i),y: Math.round(this.shapeList[a].style.y * n)}})
            }
        },add: function(e) {
            var t = o.get(e, "name"), i = o.get(e, "value"), a = null != o.get(e, "series") ? o.get(e, "series").name : "", r = this.getFont(this.option.island.textStyle), s = this.option.island, l = {zlevel: s.zlevel,z: s.z,style: {x: e.style.x,y: e.style.y,r: this.option.island.r,color: e.style.color || e.style.strokeColor,text: t + this._valueConnector + i,textFont: r},draggable: !0,hoverable: !0,onmousewheel: this.shapeHandler.onmousewheel,_type: "island"};
            "#fff" === l.style.color && (l.style.color = e.style.strokeColor), this.setCalculable(l), l.dragEnableTime = 0, o.pack(l, {name: a}, -1, i, -1, t), l = new n(l), this.shapeList.push(l), this.zr.addShape(l)
        },del: function(e) {
            this.zr.delShape(e.id);
            for (var t = [], i = 0, n = this.shapeList.length; n > i; i++)
                this.shapeList[i].id != e.id && t.push(this.shapeList[i]);
            this.shapeList = t
        },ondrop: function(e, t) {
            if (this.isDrop && e.target) {
                var i = e.target, n = e.dragged;
                this._combine(i, n), this.zr.modShape(i.id), t.dragIn = !0, this.isDrop = !1
            }
        },ondragend: function(e, t) {
            var i = e.target;
            this.isDragend ? t.dragIn && (this.del(i), t.needRefresh = !0) : t.dragIn || (i.style.x = s.getX(e.event), i.style.y = s.getY(e.event), this.add(i), t.needRefresh = !0), this.isDragend = !1
        }}, r.inherits(t, i), e("../chart").define("island", t), t
}), define("echarts/component/toolbox", ["require", "./base", "zrender/shape/Line", "zrender/shape/Image", "zrender/shape/Rectangle", "../util/shape/Icon", "../config", "zrender/tool/util", "zrender/config", "zrender/tool/event", "./dataView", "../component"], function(e) {
    function t(e, t, n, a, o) {
        i.call(this, e, t, n, a, o), this.dom = o.dom, this._magicType = {}, this._magicMap = {}, this._isSilence = !1, this._iconList, this._iconShapeMap = {}, this._featureTitle = {}, this._featureIcon = {}, this._featureColor = {}, this._featureOption = {}, this._enableColor = "red", this._disableColor = "#ccc", this._markShapeList = [];
        var r = this;
        r._onMark = function(e) {
            r.__onMark(e)
        }, r._onMarkUndo = function(e) {
            r.__onMarkUndo(e)
        }, r._onMarkClear = function(e) {
            r.__onMarkClear(e)
        }, r._onDataZoom = function(e) {
            r.__onDataZoom(e)
        }, r._onDataZoomReset = function(e) {
            r.__onDataZoomReset(e)
        }, r._onDataView = function(e) {
            r.__onDataView(e)
        }, r._onRestore = function(e) {
            r.__onRestore(e)
        }, r._onSaveAsImage = function(e) {
            r.__onSaveAsImage(e)
        }, r._onMagicType = function(e) {
            r.__onMagicType(e)
        }, r._onCustomHandler = function(e) {
            r.__onCustomHandler(e)
        }, r._onmousemove = function(e) {
            return r.__onmousemove(e)
        }, r._onmousedown = function(e) {
            return r.__onmousedown(e)
        }, r._onmouseup = function(e) {
            return r.__onmouseup(e)
        }, r._onclick = function(e) {
            return r.__onclick(e)
        }
    }
    var i = e("./base"), n = e("zrender/shape/Line"), a = e("zrender/shape/Image"), o = e("zrender/shape/Rectangle"), r = e("../util/shape/Icon"), s = e("../config");
    s.toolbox = {zlevel: 0,z: 6,show: !1,orient: "horizontal",x: "right",y: "top",color: ["#1e90ff", "#22bb22", "#4b0082", "#d2691e"],disableColor: "#ddd",effectiveColor: "red",backgroundColor: "rgba(0,0,0,0)",borderColor: "#ccc",borderWidth: 0,padding: 5,itemGap: 10,itemSize: 16,showTitle: !0,feature: {mark: {show: !1,title: {mark: "辅助线开关",markUndo: "删除辅助线",markClear: "清空辅助线"},lineStyle: {width: 1,color: "#1e90ff",type: "dashed"}},dataZoom: {show: !1,title: {dataZoom: "区域缩放",dataZoomReset: "区域缩放后退"}},dataView: {show: !1,title: "数据视图",readOnly: !1,lang: ["数据视图", "关闭", "刷新"]},magicType: {show: !1,title: {line: "折线图切换",bar: "柱形图切换",stack: "堆积",tiled: "平铺",force: "力导向布局图切换",chord: "和弦图切换",pie: "饼图切换",funnel: "漏斗图切换"},type: []},restore: {show: !1,title: "还原"},saveAsImage: {show: !1,title: "保存为图片",type: "png",lang: ["点击保存"]}}};
    var l = e("zrender/tool/util"), h = e("zrender/config"), d = e("zrender/tool/event"), c = "stack", m = "tiled";
    return t.prototype = {type: s.COMPONENT_TYPE_TOOLBOX,_buildShape: function() {
            this._iconList = [];
            var e = this.option.toolbox;
            this._enableColor = e.effectiveColor, this._disableColor = e.disableColor;
            var t = e.feature, i = [];
            for (var n in t)
                if (t[n].show)
                    switch (n) {
                        case "mark":
                            i.push({key: n,name: "mark"}), i.push({key: n,name: "markUndo"}), i.push({key: n,name: "markClear"});
                            break;
                        case "magicType":
                            for (var a = 0, o = t[n].type.length; o > a; a++)
                                t[n].title[t[n].type[a] + "Chart"] = t[n].title[t[n].type[a]], t[n].option && (t[n].option[t[n].type[a] + "Chart"] = t[n].option[t[n].type[a]]), i.push({key: n,name: t[n].type[a] + "Chart"});
                            break;
                        case "dataZoom":
                            i.push({key: n,name: "dataZoom"}), i.push({key: n,name: "dataZoomReset"});
                            break;
                        case "saveAsImage":
                            this.canvasSupported && i.push({key: n,name: "saveAsImage"});
                            break;
                        default:
                            i.push({key: n,name: n})
                    }
            if (i.length > 0) {
                for (var r, n, a = 0, o = i.length; o > a; a++)
                    r = i[a].name, n = i[a].key, this._iconList.push(r), this._featureTitle[r] = t[n].title[r] || t[n].title, t[n].icon && (this._featureIcon[r] = t[n].icon[r] || t[n].icon), t[n].color && (this._featureColor[r] = t[n].color[r] || t[n].color), t[n].option && (this._featureOption[r] = t[n].option[r] || t[n].option);
                this._itemGroupLocation = this._getItemGroupLocation(), this._buildBackground(), this._buildItem();
                for (var a = 0, o = this.shapeList.length; o > a; a++)
                    this.zr.addShape(this.shapeList[a]);
                this._iconShapeMap.mark && (this._iconDisable(this._iconShapeMap.markUndo), this._iconDisable(this._iconShapeMap.markClear)), this._iconShapeMap.dataZoomReset && 0 === this._zoomQueue.length && this._iconDisable(this._iconShapeMap.dataZoomReset)
            }
        },_buildItem: function() {
            var t, i, n, o, s = this.option.toolbox, l = this._iconList.length, h = this._itemGroupLocation.x, d = this._itemGroupLocation.y, c = s.itemSize, m = s.itemGap, p = s.color instanceof Array ? s.color : [s.color], u = this.getFont(s.textStyle);
            "horizontal" === s.orient ? (i = this._itemGroupLocation.y / this.zr.getHeight() < .5 ? "bottom" : "top", n = this._itemGroupLocation.x / this.zr.getWidth() < .5 ? "left" : "right", o = this._itemGroupLocation.y / this.zr.getHeight() < .5 ? "top" : "bottom") : i = this._itemGroupLocation.x / this.zr.getWidth() < .5 ? "right" : "left", this._iconShapeMap = {};
            for (var V = this, U = 0; l > U; U++) {
                switch (t = {type: "icon",zlevel: this.getZlevelBase(),z: this.getZBase(),style: {x: h,y: d,width: c,height: c,iconType: this._iconList[U],lineWidth: 1,strokeColor: this._featureColor[this._iconList[U]] || p[U % p.length],brushType: "stroke"},highlightStyle: {lineWidth: 1,text: s.showTitle ? this._featureTitle[this._iconList[U]] : void 0,textFont: u,textPosition: i,strokeColor: this._featureColor[this._iconList[U]] || p[U % p.length]},hoverable: !0,clickable: !0}, this._featureIcon[this._iconList[U]] && (t.style.image = this._featureIcon[this._iconList[U]].replace(new RegExp("^image:\\/\\/"), ""), t.style.opacity = .8, t.highlightStyle.opacity = 1, t.type = "image"), "horizontal" === s.orient && (0 === U && "left" === n && (t.highlightStyle.textPosition = "specific", t.highlightStyle.textAlign = n, t.highlightStyle.textBaseline = o, t.highlightStyle.textX = h, t.highlightStyle.textY = "top" === o ? d + c + 10 : d - 10), U === l - 1 && "right" === n && (t.highlightStyle.textPosition = "specific", t.highlightStyle.textAlign = n, t.highlightStyle.textBaseline = o, t.highlightStyle.textX = h + c, t.highlightStyle.textY = "top" === o ? d + c + 10 : d - 10)), this._iconList[U]) {
                    case "mark":
                        t.onclick = V._onMark;
                        break;
                    case "markUndo":
                        t.onclick = V._onMarkUndo;
                        break;
                    case "markClear":
                        t.onclick = V._onMarkClear;
                        break;
                    case "dataZoom":
                        t.onclick = V._onDataZoom;
                        break;
                    case "dataZoomReset":
                        t.onclick = V._onDataZoomReset;
                        break;
                    case "dataView":
                        if (!this._dataView) {
                            var g = e("./dataView");
                            this._dataView = new g(this.ecTheme, this.messageCenter, this.zr, this.option, this.myChart)
                        }
                        t.onclick = V._onDataView;
                        break;
                    case "restore":
                        t.onclick = V._onRestore;
                        break;
                    case "saveAsImage":
                        t.onclick = V._onSaveAsImage;
                        break;
                    default:
                        this._iconList[U].match("Chart") ? (t._name = this._iconList[U].replace("Chart", ""), t.onclick = V._onMagicType) : t.onclick = V._onCustomHandler
                }
                "icon" === t.type ? t = new r(t) : "image" === t.type && (t = new a(t)), this.shapeList.push(t), this._iconShapeMap[this._iconList[U]] = t, "horizontal" === s.orient ? h += c + m : d += c + m
            }
        },_buildBackground: function() {
            var e = this.option.toolbox, t = this.reformCssArray(this.option.toolbox.padding);
            this.shapeList.push(new o({zlevel: this.getZlevelBase(),z: this.getZBase(),hoverable: !1,style: {x: this._itemGroupLocation.x - t[3],y: this._itemGroupLocation.y - t[0],width: this._itemGroupLocation.width + t[3] + t[1],height: this._itemGroupLocation.height + t[0] + t[2],brushType: 0 === e.borderWidth ? "fill" : "both",color: e.backgroundColor,strokeColor: e.borderColor,lineWidth: e.borderWidth}}))
        },_getItemGroupLocation: function() {
            var e = this.option.toolbox, t = this.reformCssArray(this.option.toolbox.padding), i = this._iconList.length, n = e.itemGap, a = e.itemSize, o = 0, r = 0;
            "horizontal" === e.orient ? (o = (a + n) * i - n, r = a) : (r = (a + n) * i - n, o = a);
            var s, l = this.zr.getWidth();
            switch (e.x) {
                case "center":
                    s = Math.floor((l - o) / 2);
                    break;
                case "left":
                    s = t[3] + e.borderWidth;
                    break;
                case "right":
                    s = l - o - t[1] - e.borderWidth;
                    break;
                default:
                    s = e.x - 0, s = isNaN(s) ? 0 : s
            }
            var h, d = this.zr.getHeight();
            switch (e.y) {
                case "top":
                    h = t[0] + e.borderWidth;
                    break;
                case "bottom":
                    h = d - r - t[2] - e.borderWidth;
                    break;
                case "center":
                    h = Math.floor((d - r) / 2);
                    break;
                default:
                    h = e.y - 0, h = isNaN(h) ? 0 : h
            }
            return {x: s,y: h,width: o,height: r}
        },__onmousemove: function(e) {
            this._marking && (this._markShape.style.xEnd = d.getX(e.event), this._markShape.style.yEnd = d.getY(e.event), this.zr.addHoverShape(this._markShape)), this._zooming && (this._zoomShape.style.width = d.getX(e.event) - this._zoomShape.style.x, this._zoomShape.style.height = d.getY(e.event) - this._zoomShape.style.y, this.zr.addHoverShape(this._zoomShape), this.dom.style.cursor = "crosshair", d.stop(e.event)), this._zoomStart && "pointer" != this.dom.style.cursor && "move" != this.dom.style.cursor && (this.dom.style.cursor = "crosshair")
        },__onmousedown: function(e) {
            if (!e.target) {
                this._zooming = !0;
                var t = d.getX(e.event), i = d.getY(e.event), n = this.option.dataZoom || {};
                return this._zoomShape = new o({zlevel: this.getZlevelBase(),z: this.getZBase(),style: {x: t,y: i,width: 1,height: 1,brushType: "both"},highlightStyle: {lineWidth: 2,color: n.fillerColor || s.dataZoom.fillerColor,strokeColor: n.handleColor || s.dataZoom.handleColor,brushType: "both"}}), this.zr.addHoverShape(this._zoomShape), !0
            }
        },__onmouseup: function() {
            if (!this._zoomShape || Math.abs(this._zoomShape.style.width) < 10 || Math.abs(this._zoomShape.style.height) < 10)
                return this._zooming = !1, !0;
            if (this._zooming && this.component.dataZoom) {
                this._zooming = !1;
                var e = this.component.dataZoom.rectZoom(this._zoomShape.style);
                e && (this._zoomQueue.push({start: e.start,end: e.end,start2: e.start2,end2: e.end2}), this._iconEnable(this._iconShapeMap.dataZoomReset), this.zr.refreshNextFrame())
            }
            return !0
        },__onclick: function(e) {
            if (!e.target)
                if (this._marking)
                    this._marking = !1, this._markShapeList.push(this._markShape), this._iconEnable(this._iconShapeMap.markUndo), this._iconEnable(this._iconShapeMap.markClear), this.zr.addShape(this._markShape), this.zr.refreshNextFrame();
                else if (this._markStart) {
                    this._marking = !0;
                    var t = d.getX(e.event), i = d.getY(e.event);
                    this._markShape = new n({zlevel: this.getZlevelBase(),z: this.getZBase(),style: {xStart: t,yStart: i,xEnd: t,yEnd: i,lineWidth: this.query(this.option, "toolbox.feature.mark.lineStyle.width"),strokeColor: this.query(this.option, "toolbox.feature.mark.lineStyle.color"),lineType: this.query(this.option, "toolbox.feature.mark.lineStyle.type")}}), this.zr.addHoverShape(this._markShape)
                }
        },__onMark: function(e) {
            var t = e.target;
            if (this._marking || this._markStart)
                this._resetMark(), this.zr.refreshNextFrame();
            else {
                this._resetZoom(), this.zr.modShape(t.id, {style: {strokeColor: this._enableColor}}), this.zr.refreshNextFrame(), this._markStart = !0;
                var i = this;
                setTimeout(function() {
                    i.zr && i.zr.on(h.EVENT.CLICK, i._onclick) && i.zr.on(h.EVENT.MOUSEMOVE, i._onmousemove)
                }, 10)
            }
            return !0
        },__onMarkUndo: function() {
            if (this._marking)
                this._marking = !1;
            else {
                var e = this._markShapeList.length;
                if (e >= 1) {
                    var t = this._markShapeList[e - 1];
                    this.zr.delShape(t.id), this.zr.refreshNextFrame(), this._markShapeList.pop(), 1 === e && (this._iconDisable(this._iconShapeMap.markUndo), this._iconDisable(this._iconShapeMap.markClear))
                }
            }
            return !0
        },__onMarkClear: function() {
            this._marking && (this._marking = !1);
            var e = this._markShapeList.length;
            if (e > 0) {
                for (; e--; )
                    this.zr.delShape(this._markShapeList.pop().id);
                this._iconDisable(this._iconShapeMap.markUndo), this._iconDisable(this._iconShapeMap.markClear), this.zr.refreshNextFrame()
            }
            return !0
        },__onDataZoom: function(e) {
            var t = e.target;
            if (this._zooming || this._zoomStart)
                this._resetZoom(), this.zr.refreshNextFrame(), this.dom.style.cursor = "default";
            else {
                this._resetMark(), this.zr.modShape(t.id, {style: {strokeColor: this._enableColor}}), this.zr.refreshNextFrame(), this._zoomStart = !0;
                var i = this;
                setTimeout(function() {
                    i.zr && i.zr.on(h.EVENT.MOUSEDOWN, i._onmousedown) && i.zr.on(h.EVENT.MOUSEUP, i._onmouseup) && i.zr.on(h.EVENT.MOUSEMOVE, i._onmousemove)
                }, 10), this.dom.style.cursor = "crosshair"
            }
            return !0
        },__onDataZoomReset: function() {
            return this._zooming && (this._zooming = !1), this._zoomQueue.pop(), this._zoomQueue.length > 0 ? this.component.dataZoom.absoluteZoom(this._zoomQueue[this._zoomQueue.length - 1]) : (this.component.dataZoom.rectZoom(), this._iconDisable(this._iconShapeMap.dataZoomReset), this.zr.refreshNextFrame()), !0
        },_resetMark: function() {
            this._marking = !1, this._markStart && (this._markStart = !1, this._iconShapeMap.mark && this.zr.modShape(this._iconShapeMap.mark.id, {style: {strokeColor: this._iconShapeMap.mark.highlightStyle.strokeColor}}), this.zr.un(h.EVENT.CLICK, this._onclick), this.zr.un(h.EVENT.MOUSEMOVE, this._onmousemove))
        },_resetZoom: function() {
            this._zooming = !1, this._zoomStart && (this._zoomStart = !1, this._iconShapeMap.dataZoom && this.zr.modShape(this._iconShapeMap.dataZoom.id, {style: {strokeColor: this._iconShapeMap.dataZoom.highlightStyle.strokeColor}}), this.zr.un(h.EVENT.MOUSEDOWN, this._onmousedown), this.zr.un(h.EVENT.MOUSEUP, this._onmouseup), this.zr.un(h.EVENT.MOUSEMOVE, this._onmousemove))
        },_iconDisable: function(e) {
            "image" != e.type ? this.zr.modShape(e.id, {hoverable: !1,clickable: !1,style: {strokeColor: this._disableColor}}) : this.zr.modShape(e.id, {hoverable: !1,clickable: !1,style: {opacity: .3}})
        },_iconEnable: function(e) {
            "image" != e.type ? this.zr.modShape(e.id, {hoverable: !0,clickable: !0,style: {strokeColor: e.highlightStyle.strokeColor}}) : this.zr.modShape(e.id, {hoverable: !0,clickable: !0,style: {opacity: .8}})
        },__onDataView: function() {
            return this._dataView.show(this.option), !0
        },__onRestore: function() {
            return this._resetMark(), this._resetZoom(), this.messageCenter.dispatch(s.EVENT.RESTORE, null, null, this.myChart), !0
        },__onSaveAsImage: function() {
            var e = this.option.toolbox.feature.saveAsImage, t = e.type || "png";
            "png" != t && "jpeg" != t && (t = "png");
            var i;
            i = this.myChart.isConnected() ? this.myChart.getConnectedDataURL(t) : this.zr.toDataURL("image/" + t, this.option.backgroundColor && "rgba(0,0,0,0)" === this.option.backgroundColor.replace(" ", "") ? "#fff" : this.option.backgroundColor);
            var n = document.createElement("div");
            n.id = "__echarts_download_wrap__", n.style.cssText = "position:fixed;z-index:99999;display:block;top:0;left:0;background-color:rgba(33,33,33,0.5);text-align:center;width:100%;height:100%;line-height:" + document.documentElement.clientHeight + "px;";
            var a = document.createElement("a");
            a.href = i, a.setAttribute("download", (e.name ? e.name : this.option.title && (this.option.title.text || this.option.title.subtext) ? this.option.title.text || this.option.title.subtext : "ECharts") + "." + t), a.innerHTML = '<img style="vertical-align:middle" src="' + i + '" title="' + (window.ActiveXObject || "ActiveXObject" in window ? "右键->图片另存为" : e.lang ? e.lang[0] : "点击保存") + '"/>', n.appendChild(a), document.body.appendChild(n), a = null, n = null, setTimeout(function() {
                var e = document.getElementById("__echarts_download_wrap__");
                e && (e.onclick = function() {
                    var e = document.getElementById("__echarts_download_wrap__");
                    e.onclick = null, e.innerHTML = "", document.body.removeChild(e), e = null
                }, e = null)
            }, 500)
        },__onMagicType: function(e) {
            this._resetMark();
            var t = e.target._name;
            return this._magicType[t] || (this._magicType[t] = !0, t === s.CHART_TYPE_LINE ? this._magicType[s.CHART_TYPE_BAR] = !1 : t === s.CHART_TYPE_BAR && (this._magicType[s.CHART_TYPE_LINE] = !1), t === s.CHART_TYPE_PIE ? this._magicType[s.CHART_TYPE_FUNNEL] = !1 : t === s.CHART_TYPE_FUNNEL && (this._magicType[s.CHART_TYPE_PIE] = !1), t === s.CHART_TYPE_FORCE ? this._magicType[s.CHART_TYPE_CHORD] = !1 : t === s.CHART_TYPE_CHORD && (this._magicType[s.CHART_TYPE_FORCE] = !1), t === c ? this._magicType[m] = !1 : t === m && (this._magicType[c] = !1), this.messageCenter.dispatch(s.EVENT.MAGIC_TYPE_CHANGED, e.event, {magicType: this._magicType}, this.myChart)), !0
        },setMagicType: function(e) {
            this._resetMark(), this._magicType = e, !this._isSilence && this.messageCenter.dispatch(s.EVENT.MAGIC_TYPE_CHANGED, null, {magicType: this._magicType}, this.myChart)
        },__onCustomHandler: function(e) {
            var t = e.target.style.iconType, i = this.option.toolbox.feature[t].onclick;
            "function" == typeof i && i.call(this, this.option)
        },reset: function(e, t) {
            if (t && this.clear(), this.query(e, "toolbox.show") && this.query(e, "toolbox.feature.magicType.show")) {
                var i = e.toolbox.feature.magicType.type, n = i.length;
                for (this._magicMap = {}; n--; )
                    this._magicMap[i[n]] = !0;
                n = e.series.length;
                for (var a, o; n--; )
                    a = e.series[n].type, this._magicMap[a] && (o = e.xAxis instanceof Array ? e.xAxis[e.series[n].xAxisIndex || 0] : e.xAxis, o && "category" === (o.type || "category") && (o.__boundaryGap = null != o.boundaryGap ? o.boundaryGap : !0), o = e.yAxis instanceof Array ? e.yAxis[e.series[n].yAxisIndex || 0] : e.yAxis, o && "category" === o.type && (o.__boundaryGap = null != o.boundaryGap ? o.boundaryGap : !0), e.series[n].__type = a, e.series[n].__itemStyle = l.clone(e.series[n].itemStyle || {})), (this._magicMap[c] || this._magicMap[m]) && (e.series[n].__stack = e.series[n].stack)
            }
            this._magicType = t ? {} : this._magicType || {};
            for (var r in this._magicType)
                if (this._magicType[r]) {
                    this.option = e, this.getMagicOption();
                    break
                }
            var s = e.dataZoom;
            if (s && s.show) {
                var h = null != s.start && s.start >= 0 && s.start <= 100 ? s.start : 0, d = null != s.end && s.end >= 0 && s.end <= 100 ? s.end : 100;
                h > d && (h += d, d = h - d, h -= d), this._zoomQueue = [{start: h,end: d,start2: 0,end2: 100}]
            } else
                this._zoomQueue = []
        },getMagicOption: function() {
            var e, t;
            if (this._magicType[s.CHART_TYPE_LINE] || this._magicType[s.CHART_TYPE_BAR]) {
                for (var i = this._magicType[s.CHART_TYPE_LINE] ? !1 : !0, n = 0, a = this.option.series.length; a > n; n++)
                    t = this.option.series[n].type, (t == s.CHART_TYPE_LINE || t == s.CHART_TYPE_BAR) && (e = this.option.xAxis instanceof Array ? this.option.xAxis[this.option.series[n].xAxisIndex || 0] : this.option.xAxis, e && "category" === (e.type || "category") && (e.boundaryGap = i ? !0 : e.__boundaryGap), e = this.option.yAxis instanceof Array ? this.option.yAxis[this.option.series[n].yAxisIndex || 0] : this.option.yAxis, e && "category" === e.type && (e.boundaryGap = i ? !0 : e.__boundaryGap));
                this._defaultMagic(s.CHART_TYPE_LINE, s.CHART_TYPE_BAR)
            }
            if (this._defaultMagic(s.CHART_TYPE_CHORD, s.CHART_TYPE_FORCE), this._defaultMagic(s.CHART_TYPE_PIE, s.CHART_TYPE_FUNNEL), this._magicType[c] || this._magicType[m])
                for (var n = 0, a = this.option.series.length; a > n; n++)
                    this._magicType[c] ? (this.option.series[n].stack = "_ECHARTS_STACK_KENER_2014_", t = c) : this._magicType[m] && (this.option.series[n].stack = null, t = m), this._featureOption[t + "Chart"] && l.merge(this.option.series[n], this._featureOption[t + "Chart"] || {}, !0);
            return this.option
        },_defaultMagic: function(e, t) {
            if (this._magicType[e] || this._magicType[t])
                for (var i = 0, n = this.option.series.length; n > i; i++) {
                    var a = this.option.series[i].type;
                    (a == e || a == t) && (this.option.series[i].type = this._magicType[e] ? e : t, this.option.series[i].itemStyle = l.clone(this.option.series[i].__itemStyle), a = this.option.series[i].type, this._featureOption[a + "Chart"] && l.merge(this.option.series[i], this._featureOption[a + "Chart"] || {}, !0))
                }
        },silence: function(e) {
            this._isSilence = e
        },resize: function() {
            this._resetMark(), this.clear(), this.option && this.option.toolbox && this.option.toolbox.show && this._buildShape(), this._dataView && this._dataView.resize()
        },hideDataView: function() {
            this._dataView && this._dataView.hide()
        },clear: function(e) {
            this.zr && (this.zr.delShape(this.shapeList), this.shapeList = [], e || (this.zr.delShape(this._markShapeList), this._markShapeList = []))
        },onbeforDispose: function() {
            this._dataView && (this._dataView.dispose(), this._dataView = null), this._markShapeList = null
        },refresh: function(e) {
            e && (this._resetMark(), this._resetZoom(), e.toolbox = this.reformOption(e.toolbox), this.option = e, this.clear(!0), e.toolbox.show && this._buildShape(), this.hideDataView())
        }}, l.inherits(t, i), e("../component").define("toolbox", t), t
}), define("echarts/component", [], function() {
    var e = {}, t = {};
    return e.define = function(i, n) {
        return t[i] = n, e
    }, e.get = function(e) {
        return t[e]
    }, e
}), define("echarts/component/title", ["require", "./base", "zrender/shape/Text", "zrender/shape/Rectangle", "../config", "zrender/tool/util", "zrender/tool/area", "zrender/tool/color", "../component"], function(e) {
    function t(e, t, n, a, o) {
        i.call(this, e, t, n, a, o), this.refresh(a)
    }
    var i = e("./base"), n = e("zrender/shape/Text"), a = e("zrender/shape/Rectangle"), o = e("../config");
    o.title = {zlevel: 0,z: 6,show: !0,text: "",subtext: "",x: "left",y: "top",backgroundColor: "rgba(0,0,0,0)",borderColor: "#ccc",borderWidth: 0,padding: 5,itemGap: 5,textStyle: {fontSize: 18,fontWeight: "bolder",color: "#333"},subtextStyle: {color: "#aaa"}};
    var r = e("zrender/tool/util"), s = e("zrender/tool/area"), l = e("zrender/tool/color");
    return t.prototype = {type: o.COMPONENT_TYPE_TITLE,_buildShape: function() {
            if (this.titleOption.show) {
                this._itemGroupLocation = this._getItemGroupLocation(), this._buildBackground(), this._buildItem();
                for (var e = 0, t = this.shapeList.length; t > e; e++)
                    this.zr.addShape(this.shapeList[e])
            }
        },_buildItem: function() {
            var e = this.titleOption.text, t = this.titleOption.link, i = this.titleOption.target, a = this.titleOption.subtext, o = this.titleOption.sublink, r = this.titleOption.subtarget, s = this.getFont(this.titleOption.textStyle), h = this.getFont(this.titleOption.subtextStyle), d = this._itemGroupLocation.x, c = this._itemGroupLocation.y, m = this._itemGroupLocation.width, p = this._itemGroupLocation.height, u = {zlevel: this.getZlevelBase(),z: this.getZBase(),style: {y: c,color: this.titleOption.textStyle.color,text: e,textFont: s,textBaseline: "top"},highlightStyle: {color: l.lift(this.titleOption.textStyle.color, 1),brushType: "fill"},hoverable: !1};
            t && (u.hoverable = !0, u.clickable = !0, u.onclick = function() {
                i && "self" == i ? window.location = t : window.open(t)
            });
            var V = {zlevel: this.getZlevelBase(),z: this.getZBase(),
                style: {y: c + p,color: this.titleOption.subtextStyle.color,text: a,textFont: h,textBaseline: "bottom"},highlightStyle: {color: l.lift(this.titleOption.subtextStyle.color, 1),brushType: "fill"},hoverable: !1};
            switch (o && (V.hoverable = !0, V.clickable = !0, V.onclick = function() {
                r && "self" == r ? window.location = o : window.open(o)
            }), this.titleOption.x) {
                case "center":
                    u.style.x = V.style.x = d + m / 2, u.style.textAlign = V.style.textAlign = "center";
                    break;
                case "left":
                    u.style.x = V.style.x = d, u.style.textAlign = V.style.textAlign = "left";
                    break;
                case "right":
                    u.style.x = V.style.x = d + m, u.style.textAlign = V.style.textAlign = "right";
                    break;
                default:
                    d = this.titleOption.x - 0, d = isNaN(d) ? 0 : d, u.style.x = V.style.x = d
            }
            this.titleOption.textAlign && (u.style.textAlign = V.style.textAlign = this.titleOption.textAlign), this.shapeList.push(new n(u)), "" !== a && this.shapeList.push(new n(V))
        },_buildBackground: function() {
            var e = this.reformCssArray(this.titleOption.padding);
            this.shapeList.push(new a({zlevel: this.getZlevelBase(),z: this.getZBase(),hoverable: !1,style: {x: this._itemGroupLocation.x - e[3],y: this._itemGroupLocation.y - e[0],width: this._itemGroupLocation.width + e[3] + e[1],height: this._itemGroupLocation.height + e[0] + e[2],brushType: 0 === this.titleOption.borderWidth ? "fill" : "both",color: this.titleOption.backgroundColor,strokeColor: this.titleOption.borderColor,lineWidth: this.titleOption.borderWidth}}))
        },_getItemGroupLocation: function() {
            var e, t = this.reformCssArray(this.titleOption.padding), i = this.titleOption.text, n = this.titleOption.subtext, a = this.getFont(this.titleOption.textStyle), o = this.getFont(this.titleOption.subtextStyle), r = Math.max(s.getTextWidth(i, a), s.getTextWidth(n, o)), l = s.getTextHeight(i, a) + ("" === n ? 0 : this.titleOption.itemGap + s.getTextHeight(n, o)), h = this.zr.getWidth();
            switch (this.titleOption.x) {
                case "center":
                    e = Math.floor((h - r) / 2);
                    break;
                case "left":
                    e = t[3] + this.titleOption.borderWidth;
                    break;
                case "right":
                    e = h - r - t[1] - this.titleOption.borderWidth;
                    break;
                default:
                    e = this.titleOption.x - 0, e = isNaN(e) ? 0 : e
            }
            var d, c = this.zr.getHeight();
            switch (this.titleOption.y) {
                case "top":
                    d = t[0] + this.titleOption.borderWidth;
                    break;
                case "bottom":
                    d = c - l - t[2] - this.titleOption.borderWidth;
                    break;
                case "center":
                    d = Math.floor((c - l) / 2);
                    break;
                default:
                    d = this.titleOption.y - 0, d = isNaN(d) ? 0 : d
            }
            return {x: e,y: d,width: r,height: l}
        },refresh: function(e) {
            e && (this.option = e, this.option.title = this.reformOption(this.option.title), this.titleOption = this.option.title, this.titleOption.textStyle = this.getTextStyle(this.titleOption.textStyle), this.titleOption.subtextStyle = this.getTextStyle(this.titleOption.subtextStyle)), this.clear(), this._buildShape()
        }}, r.inherits(t, i), e("../component").define("title", t), t
}), define("echarts/component/tooltip", ["require", "./base", "../util/shape/Cross", "zrender/shape/Line", "zrender/shape/Rectangle", "../config", "../util/ecData", "zrender/config", "zrender/tool/event", "zrender/tool/area", "zrender/tool/color", "zrender/tool/util", "zrender/shape/Base", "../component"], function(e) {
    function t(e, t, o, r, s) {
        i.call(this, e, t, o, r, s), this.dom = s.dom;
        var l = this;
        l._onmousemove = function(e) {
            return l.__onmousemove(e)
        }, l._onglobalout = function(e) {
            return l.__onglobalout(e)
        }, this.zr.on(h.EVENT.MOUSEMOVE, l._onmousemove), this.zr.on(h.EVENT.GLOBALOUT, l._onglobalout), l._hide = function(e) {
            return l.__hide(e)
        }, l._tryShow = function(e) {
            return l.__tryShow(e)
        }, l._refixed = function(e) {
            return l.__refixed(e)
        }, l._setContent = function(e, t) {
            return l.__setContent(e, t)
        }, this._tDom = this._tDom || document.createElement("div"), this._tDom.onselectstart = function() {
            return !1
        }, this._tDom.onmouseover = function() {
            l._mousein = !0
        }, this._tDom.onmouseout = function() {
            l._mousein = !1
        }, this._tDom.className = "echarts-tooltip", this._tDom.style.position = "absolute", this.hasAppend = !1, this._axisLineShape && this.zr.delShape(this._axisLineShape.id), this._axisLineShape = new a({zlevel: this.getZlevelBase(),z: this.getZBase(),invisible: !0,hoverable: !1}), this.shapeList.push(this._axisLineShape), this.zr.addShape(this._axisLineShape), this._axisShadowShape && this.zr.delShape(this._axisShadowShape.id), this._axisShadowShape = new a({zlevel: this.getZlevelBase(),z: 1,invisible: !0,hoverable: !1}), this.shapeList.push(this._axisShadowShape), this.zr.addShape(this._axisShadowShape), this._axisCrossShape && this.zr.delShape(this._axisCrossShape.id), this._axisCrossShape = new n({zlevel: this.getZlevelBase(),z: this.getZBase(),invisible: !0,hoverable: !1}), this.shapeList.push(this._axisCrossShape), this.zr.addShape(this._axisCrossShape), this.showing = !1, this.refresh(r)
    }
    var i = e("./base"), n = e("../util/shape/Cross"), a = e("zrender/shape/Line"), o = e("zrender/shape/Rectangle"), r = new o({}), s = e("../config");
    s.tooltip = {zlevel: 1,z: 8,show: !0,showContent: !0,trigger: "item",islandFormatter: "{a} <br/>{b} : {c}",showDelay: 20,hideDelay: 100,transitionDuration: .4,enterable: !1,backgroundColor: "rgba(0,0,0,0.7)",borderColor: "#333",borderRadius: 4,borderWidth: 0,padding: 5,axisPointer: {type: "line",lineStyle: {color: "#48b",width: 2,type: "solid"},crossStyle: {color: "#1e90ff",width: 1,type: "dashed"},shadowStyle: {color: "rgba(150,150,150,0.3)",width: "auto",type: "default"}},textStyle: {color: "#fff"}};
    var l = e("../util/ecData"), h = e("zrender/config"), d = e("zrender/tool/event"), c = e("zrender/tool/area"), m = e("zrender/tool/color"), p = e("zrender/tool/util"), u = e("zrender/shape/Base");
    return t.prototype = {type: s.COMPONENT_TYPE_TOOLTIP,_gCssText: "position:absolute;display:block;border-style:solid;white-space:nowrap;",_style: function(e) {
            if (!e)
                return "";
            var t = [];
            if (e.transitionDuration) {
                var i = "left " + e.transitionDuration + "s,top " + e.transitionDuration + "s";
                t.push("transition:" + i), t.push("-moz-transition:" + i), t.push("-webkit-transition:" + i), t.push("-o-transition:" + i)
            }
            e.backgroundColor && (t.push("background-Color:" + m.toHex(e.backgroundColor)), t.push("filter:alpha(opacity=70)"), t.push("background-Color:" + e.backgroundColor)), null != e.borderWidth && t.push("border-width:" + e.borderWidth + "px"), null != e.borderColor && t.push("border-color:" + e.borderColor), null != e.borderRadius && (t.push("border-radius:" + e.borderRadius + "px"), t.push("-moz-border-radius:" + e.borderRadius + "px"), t.push("-webkit-border-radius:" + e.borderRadius + "px"), t.push("-o-border-radius:" + e.borderRadius + "px"));
            var n = e.textStyle;
            n && (n.color && t.push("color:" + n.color), n.decoration && t.push("text-decoration:" + n.decoration), n.align && t.push("text-align:" + n.align), n.fontFamily && t.push("font-family:" + n.fontFamily), n.fontSize && t.push("font-size:" + n.fontSize + "px"), n.fontSize && t.push("line-height:" + Math.round(3 * n.fontSize / 2) + "px"), n.fontStyle && t.push("font-style:" + n.fontStyle), n.fontWeight && t.push("font-weight:" + n.fontWeight));
            var a = e.padding;
            return null != a && (a = this.reformCssArray(a), t.push("padding:" + a[0] + "px " + a[1] + "px " + a[2] + "px " + a[3] + "px")), t = t.join(";") + ";"
        },__hide: function() {
            this._lastDataIndex = -1, this._lastSeriesIndex = -1, this._lastItemTriggerId = -1, this._tDom && (this._tDom.style.display = "none");
            var e = !1;
            this._axisLineShape.invisible || (this._axisLineShape.invisible = !0, this.zr.modShape(this._axisLineShape.id), e = !0), this._axisShadowShape.invisible || (this._axisShadowShape.invisible = !0, this.zr.modShape(this._axisShadowShape.id), e = !0), this._axisCrossShape.invisible || (this._axisCrossShape.invisible = !0, this.zr.modShape(this._axisCrossShape.id), e = !0), this._lastTipShape && this._lastTipShape.tipShape.length > 0 && (this.zr.delShape(this._lastTipShape.tipShape), this._lastTipShape = !1, this.shapeList.length = 2), e && this.zr.refreshNextFrame(), this.showing = !1
        },_show: function(e, t, i, n) {
            var a = this._tDom.offsetHeight, o = this._tDom.offsetWidth;
            e && ("function" == typeof e && (e = e([t, i])), e instanceof Array && (t = e[0], i = e[1])), t + o > this._zrWidth && (t -= o + 40), i + a > this._zrHeight && (i -= a - 20), 20 > i && (i = 0), this._tDom.style.cssText = this._gCssText + this._defaultCssText + (n ? n : "") + "left:" + t + "px;top:" + i + "px;", (10 > a || 10 > o) && setTimeout(this._refixed, 20), this.showing = !0
        },__refixed: function() {
            if (this._tDom) {
                var e = "", t = this._tDom.offsetHeight, i = this._tDom.offsetWidth;
                this._tDom.offsetLeft + i > this._zrWidth && (e += "left:" + (this._zrWidth - i - 20) + "px;"), this._tDom.offsetTop + t > this._zrHeight && (e += "top:" + (this._zrHeight - t - 10) + "px;"), "" !== e && (this._tDom.style.cssText += e)
            }
        },__tryShow: function() {
            var e, t;
            if (this._curTarget) {
                if ("island" === this._curTarget._type && this.option.tooltip.show)
                    return void this._showItemTrigger();
                var i = l.get(this._curTarget, "series"), n = l.get(this._curTarget, "data");
                e = this.deepQuery([n, i, this.option], "tooltip.show"), null != i && null != n && e ? (t = this.deepQuery([n, i, this.option], "tooltip.trigger"), "axis" === t ? this._showAxisTrigger(i.xAxisIndex, i.yAxisIndex, l.get(this._curTarget, "dataIndex")) : this._showItemTrigger()) : (clearTimeout(this._hidingTicket), clearTimeout(this._showingTicket), this._hidingTicket = setTimeout(this._hide, this._hideDelay))
            } else
                this._findPolarTrigger() || this._findAxisTrigger()
        },_findAxisTrigger: function() {
            if (!this.component.xAxis || !this.component.yAxis)
                return void (this._hidingTicket = setTimeout(this._hide, this._hideDelay));
            for (var e, t, i = this.option.series, n = 0, a = i.length; a > n; n++)
                if ("axis" === this.deepQuery([i[n], this.option], "tooltip.trigger"))
                    return e = i[n].xAxisIndex || 0, t = i[n].yAxisIndex || 0, this.component.xAxis.getAxis(e) && this.component.xAxis.getAxis(e).type === s.COMPONENT_TYPE_AXIS_CATEGORY ? void this._showAxisTrigger(e, t, this._getNearestDataIndex("x", this.component.xAxis.getAxis(e))) : this.component.yAxis.getAxis(t) && this.component.yAxis.getAxis(t).type === s.COMPONENT_TYPE_AXIS_CATEGORY ? void this._showAxisTrigger(e, t, this._getNearestDataIndex("y", this.component.yAxis.getAxis(t))) : void this._showAxisTrigger(e, t, -1);
            "cross" === this.option.tooltip.axisPointer.type && this._showAxisTrigger(-1, -1, -1)
        },_findPolarTrigger: function() {
            if (!this.component.polar)
                return !1;
            var e, t = d.getX(this._event), i = d.getY(this._event), n = this.component.polar.getNearestIndex([t, i]);
            return n ? (e = n.valueIndex, n = n.polarIndex) : n = -1, -1 != n ? this._showPolarTrigger(n, e) : !1
        },_getNearestDataIndex: function(e, t) {
            var i = -1, n = d.getX(this._event), a = d.getY(this._event);
            if ("x" === e) {
                for (var o, r, s = this.component.grid.getXend(), l = t.getCoordByIndex(i); s > l && (r = l, n >= l); )
                    o = l, l = t.getCoordByIndex(++i);
                return 0 >= i ? i = 0 : r - n >= n - o ? i -= 1 : null == t.getNameByIndex(i) && (i -= 1), i
            }
            for (var h, c, m = this.component.grid.getY(), l = t.getCoordByIndex(i); l > m && (h = l, l >= a); )
                c = l, l = t.getCoordByIndex(++i);
            return 0 >= i ? i = 0 : a - h >= c - a ? i -= 1 : null == t.getNameByIndex(i) && (i -= 1), i
        },_showAxisTrigger: function(e, t, i) {
            if (!this._event.connectTrigger && this.messageCenter.dispatch(s.EVENT.TOOLTIP_IN_GRID, this._event, null, this.myChart), null == this.component.xAxis || null == this.component.yAxis || null == e || null == t)
                return clearTimeout(this._hidingTicket), clearTimeout(this._showingTicket), void (this._hidingTicket = setTimeout(this._hide, this._hideDelay));
            var n, a, o, r, l = this.option.series, h = [], c = [], m = "";
            if ("axis" === this.option.tooltip.trigger) {
                if (!this.option.tooltip.show)
                    return;
                a = this.option.tooltip.formatter, o = this.option.tooltip.position
            }
            var p, u, V = -1 != e && this.component.xAxis.getAxis(e).type === s.COMPONENT_TYPE_AXIS_CATEGORY ? "xAxis" : -1 != t && this.component.yAxis.getAxis(t).type === s.COMPONENT_TYPE_AXIS_CATEGORY ? "yAxis" : !1;
            if (V) {
                var U = "xAxis" == V ? e : t;
                n = this.component[V].getAxis(U);
                for (var g = 0, f = l.length; f > g; g++)
                    this._isSelected(l[g].name) && l[g][V + "Index"] === U && "axis" === this.deepQuery([l[g], this.option], "tooltip.trigger") && (r = this.query(l[g], "tooltip.showContent") || r, a = this.query(l[g], "tooltip.formatter") || a, o = this.query(l[g], "tooltip.position") || o, m += this._style(this.query(l[g], "tooltip")), null != l[g].stack && "xAxis" == V ? (h.unshift(l[g]), c.unshift(g)) : (h.push(l[g]), c.push(g)));
                this.messageCenter.dispatch(s.EVENT.TOOLTIP_HOVER, this._event, {seriesIndex: c,dataIndex: i}, this.myChart);
                var y;
                "xAxis" == V ? (p = this.subPixelOptimize(n.getCoordByIndex(i), this._axisLineWidth), u = d.getY(this._event), y = [p, this.component.grid.getY(), p, this.component.grid.getYend()]) : (p = d.getX(this._event), u = this.subPixelOptimize(n.getCoordByIndex(i), this._axisLineWidth), y = [this.component.grid.getX(), u, this.component.grid.getXend(), u]), this._styleAxisPointer(h, y[0], y[1], y[2], y[3], n.getGap(), p, u)
            } else
                p = d.getX(this._event), u = d.getY(this._event), this._styleAxisPointer(l, this.component.grid.getX(), u, this.component.grid.getXend(), u, 0, p, u), i >= 0 ? this._showItemTrigger(!0) : (clearTimeout(this._hidingTicket), clearTimeout(this._showingTicket), this._tDom.style.display = "none");
            if (h.length > 0) {
                if (this._lastItemTriggerId = -1, this._lastDataIndex != i || this._lastSeriesIndex != c[0]) {
                    this._lastDataIndex = i, this._lastSeriesIndex = c[0];
                    var b, _;
                    if ("function" == typeof a) {
                        for (var x = [], g = 0, f = h.length; f > g; g++)
                            b = h[g].data[i], _ = this.getDataFromOption(b, "-"), x.push({seriesIndex: c[g],seriesName: h[g].name || "",series: h[g],dataIndex: i,data: b,name: n.getNameByIndex(i),value: _,0: h[g].name || "",1: n.getNameByIndex(i),2: _,3: b});
                        this._curTicket = "axis:" + i, this._tDom.innerHTML = a.call(this.myChart, x, this._curTicket, this._setContent)
                    } else if ("string" == typeof a) {
                        this._curTicket = 0 / 0, a = a.replace("{a}", "{a0}").replace("{b}", "{b0}").replace("{c}", "{c0}");
                        for (var g = 0, f = h.length; f > g; g++)
                            a = a.replace("{a" + g + "}", this._encodeHTML(h[g].name || "")), a = a.replace("{b" + g + "}", this._encodeHTML(n.getNameByIndex(i))), b = h[g].data[i], b = this.getDataFromOption(b, "-"), a = a.replace("{c" + g + "}", b instanceof Array ? b : this.numAddCommas(b));
                        this._tDom.innerHTML = a
                    } else {
                        this._curTicket = 0 / 0, a = this._encodeHTML(n.getNameByIndex(i));
                        for (var g = 0, f = h.length; f > g; g++)
                            a += "<br/>" + this._encodeHTML(h[g].name || "") + " : ", b = h[g].data[i], b = this.getDataFromOption(b, "-"), a += b instanceof Array ? b : this.numAddCommas(b);
                        this._tDom.innerHTML = a
                    }
                }
                if (r === !1 || !this.option.tooltip.showContent)
                    return;
                this.hasAppend || (this._tDom.style.left = this._zrWidth / 2 + "px", this._tDom.style.top = this._zrHeight / 2 + "px", this.dom.firstChild.appendChild(this._tDom), this.hasAppend = !0), this._show(o, p + 10, u + 10, m)
            }
        },_showPolarTrigger: function(e, t) {
            if (null == this.component.polar || null == e || null == t || 0 > t)
                return !1;
            var i, n, a, o = this.option.series, r = [], s = [], l = "";
            if ("axis" === this.option.tooltip.trigger) {
                if (!this.option.tooltip.show)
                    return !1;
                i = this.option.tooltip.formatter, n = this.option.tooltip.position
            }
            for (var h = this.option.polar[e].indicator[t].text, c = 0, m = o.length; m > c; c++)
                this._isSelected(o[c].name) && o[c].polarIndex === e && "axis" === this.deepQuery([o[c], this.option], "tooltip.trigger") && (a = this.query(o[c], "tooltip.showContent") || a, i = this.query(o[c], "tooltip.formatter") || i, n = this.query(o[c], "tooltip.position") || n, l += this._style(this.query(o[c], "tooltip")), r.push(o[c]), s.push(c));
            if (r.length > 0) {
                for (var p, u, V, U = [], c = 0, m = r.length; m > c; c++) {
                    p = r[c].data;
                    for (var g = 0, f = p.length; f > g; g++)
                        u = p[g], this._isSelected(u.name) && (u = null != u ? u : {name: "",value: {dataIndex: "-"}}, V = this.getDataFromOption(u.value[t]), U.push({seriesIndex: s[c],seriesName: r[c].name || "",series: r[c],dataIndex: t,data: u,name: u.name,indicator: h,value: V,0: r[c].name || "",1: u.name,2: V,3: h}))
                }
                if (U.length <= 0)
                    return;
                if (this._lastItemTriggerId = -1, this._lastDataIndex != t || this._lastSeriesIndex != s[0])
                    if (this._lastDataIndex = t, this._lastSeriesIndex = s[0], "function" == typeof i)
                        this._curTicket = "axis:" + t, this._tDom.innerHTML = i.call(this.myChart, U, this._curTicket, this._setContent);
                    else if ("string" == typeof i) {
                        i = i.replace("{a}", "{a0}").replace("{b}", "{b0}").replace("{c}", "{c0}").replace("{d}", "{d0}");
                        for (var c = 0, m = U.length; m > c; c++)
                            i = i.replace("{a" + c + "}", this._encodeHTML(U[c].seriesName)), i = i.replace("{b" + c + "}", this._encodeHTML(U[c].name)), i = i.replace("{c" + c + "}", this.numAddCommas(U[c].value)), i = i.replace("{d" + c + "}", this._encodeHTML(U[c].indicator));
                        this._tDom.innerHTML = i
                    } else {
                        i = this._encodeHTML(U[0].name) + "<br/>" + this._encodeHTML(U[0].indicator) + " : " + this.numAddCommas(U[0].value);
                        for (var c = 1, m = U.length; m > c; c++)
                            i += "<br/>" + this._encodeHTML(U[c].name) + "<br/>", i += this._encodeHTML(U[c].indicator) + " : " + this.numAddCommas(U[c].value);
                        this._tDom.innerHTML = i
                    }
                if (a === !1 || !this.option.tooltip.showContent)
                    return;
                return this.hasAppend || (this._tDom.style.left = this._zrWidth / 2 + "px", this._tDom.style.top = this._zrHeight / 2 + "px", this.dom.firstChild.appendChild(this._tDom), this.hasAppend = !0), this._show(n, d.getX(this._event), d.getY(this._event), l), !0
            }
        },_showItemTrigger: function(e) {
            if (this._curTarget) {
                var t, i, n, a = l.get(this._curTarget, "series"), o = l.get(this._curTarget, "seriesIndex"), r = l.get(this._curTarget, "data"), h = l.get(this._curTarget, "dataIndex"), c = l.get(this._curTarget, "name"), m = l.get(this._curTarget, "value"), p = l.get(this._curTarget, "special"), u = l.get(this._curTarget, "special2"), V = [r, a, this.option], U = "";
                if ("island" != this._curTarget._type) {
                    var g = e ? "axis" : "item";
                    this.option.tooltip.trigger === g && (t = this.option.tooltip.formatter, i = this.option.tooltip.position), this.query(a, "tooltip.trigger") === g && (n = this.query(a, "tooltip.showContent") || n, t = this.query(a, "tooltip.formatter") || t, i = this.query(a, "tooltip.position") || i, U += this._style(this.query(a, "tooltip"))), n = this.query(r, "tooltip.showContent") || n, t = this.query(r, "tooltip.formatter") || t, i = this.query(r, "tooltip.position") || i, U += this._style(this.query(r, "tooltip"))
                } else
                    this._lastItemTriggerId = 0 / 0, n = this.deepQuery(V, "tooltip.showContent"), t = this.deepQuery(V, "tooltip.islandFormatter"), i = this.deepQuery(V, "tooltip.islandPosition");
                this._lastDataIndex = -1, this._lastSeriesIndex = -1, this._lastItemTriggerId !== this._curTarget.id && (this._lastItemTriggerId = this._curTarget.id, "function" == typeof t ? (this._curTicket = (a.name || "") + ":" + h, this._tDom.innerHTML = t.call(this.myChart, {seriesIndex: o,seriesName: a.name || "",series: a,dataIndex: h,data: r,name: c,value: m,percent: p,indicator: p,value2: u,indicator2: u,0: a.name || "",1: c,2: m,3: p,4: u,5: r,6: o,7: h}, this._curTicket, this._setContent)) : "string" == typeof t ? (this._curTicket = 0 / 0, t = t.replace("{a}", "{a0}").replace("{b}", "{b0}").replace("{c}", "{c0}"), t = t.replace("{a0}", this._encodeHTML(a.name || "")).replace("{b0}", this._encodeHTML(c)).replace("{c0}", m instanceof Array ? m : this.numAddCommas(m)), t = t.replace("{d}", "{d0}").replace("{d0}", p || ""), t = t.replace("{e}", "{e0}").replace("{e0}", l.get(this._curTarget, "special2") || ""), this._tDom.innerHTML = t) : (this._curTicket = 0 / 0, this._tDom.innerHTML = a.type === s.CHART_TYPE_RADAR && p ? this._itemFormatter.radar.call(this, a, c, m, p) : a.type === s.CHART_TYPE_EVENTRIVER ? this._itemFormatter.eventRiver.call(this, a, c, m, r) : "" + (null != a.name ? this._encodeHTML(a.name) + "<br/>" : "") + ("" === c ? "" : this._encodeHTML(c) + " : ") + (m instanceof Array ? m : this.numAddCommas(m))));
                var f = d.getX(this._event), y = d.getY(this._event);
                this.deepQuery(V, "tooltip.axisPointer.show") && this.component.grid ? this._styleAxisPointer([a], this.component.grid.getX(), y, this.component.grid.getXend(), y, 0, f, y) : this._hide(), n !== !1 && this.option.tooltip.showContent && (this.hasAppend || (this._tDom.style.left = this._zrWidth / 2 + "px", this._tDom.style.top = this._zrHeight / 2 + "px", this.dom.firstChild.appendChild(this._tDom), this.hasAppend = !0), this._show(i, f + 20, y - 20, U))
            }
        },_itemFormatter: {radar: function(e, t, i, n) {
                var a = "";
                a += this._encodeHTML("" === t ? e.name || "" : t), a += "" === a ? "" : "<br />";
                for (var o = 0; o < n.length; o++)
                    a += this._encodeHTML(n[o].text) + " : " + this.numAddCommas(i[o]) + "<br />";
                return a
            },chord: function(e, t, i, n, a) {
                if (null == a)
                    return this._encodeHTML(t) + " (" + this.numAddCommas(i) + ")";
                var o = this._encodeHTML(t), r = this._encodeHTML(n);
                return "" + (null != e.name ? this._encodeHTML(e.name) + "<br/>" : "") + o + " -> " + r + " (" + this.numAddCommas(i) + ")<br />" + r + " -> " + o + " (" + this.numAddCommas(a) + ")"
            },eventRiver: function(e, t, i, n) {
                var a = "";
                a += this._encodeHTML("" === e.name ? "" : e.name + " : "), a += this._encodeHTML(t), a += "" === a ? "" : "<br />", n = n.evolution;
                for (var o = 0, r = n.length; r > o; o++)
                    a += '<div style="padding-top:5px;">', n[o].detail && (n[o].detail.img && (a += '<img src="' + n[o].detail.img + '" style="float:left;width:40px;height:40px;">'), a += '<div style="margin-left:45px;">' + n[o].time + "<br/>", a += '<a href="' + n[o].detail.link + '" target="_blank">', a += n[o].detail.text + "</a></div>", a += "</div>");
                return a
            }},_styleAxisPointer: function(e, t, i, n, a, o, r, s) {
            if (e.length > 0) {
                var l, h, d = this.option.tooltip.axisPointer, c = d.type, m = {line: {},cross: {},shadow: {}};
                for (var p in m)
                    m[p].color = d[p + "Style"].color, m[p].width = d[p + "Style"].width, m[p].type = d[p + "Style"].type;
                for (var u = 0, V = e.length; V > u; u++)
                    l = e[u], h = this.query(l, "tooltip.axisPointer.type"), c = h || c, h && (m[h].color = this.query(l, "tooltip.axisPointer." + h + "Style.color") || m[h].color, m[h].width = this.query(l, "tooltip.axisPointer." + h + "Style.width") || m[h].width, m[h].type = this.query(l, "tooltip.axisPointer." + h + "Style.type") || m[h].type);
                if ("line" === c) {
                    var U = m.line.width, g = t == n;
                    this._axisLineShape.style = {xStart: g ? this.subPixelOptimize(t, U) : t,yStart: g ? i : this.subPixelOptimize(i, U),xEnd: g ? this.subPixelOptimize(n, U) : n,yEnd: g ? a : this.subPixelOptimize(a, U),strokeColor: m.line.color,lineWidth: U,lineType: m.line.type}, this._axisLineShape.invisible = !1, this.zr.modShape(this._axisLineShape.id)
                } else if ("cross" === c) {
                    var f = m.cross.width;
                    this._axisCrossShape.style = {brushType: "stroke",rect: this.component.grid.getArea(),x: this.subPixelOptimize(r, f),y: this.subPixelOptimize(s, f),text: ("( " + this.component.xAxis.getAxis(0).getValueFromCoord(r) + " , " + this.component.yAxis.getAxis(0).getValueFromCoord(s) + " )").replace("  , ", " ").replace(" ,  ", " "),textPosition: "specific",strokeColor: m.cross.color,lineWidth: f,lineType: m.cross.type}, this.component.grid.getXend() - r > 100 ? (this._axisCrossShape.style.textAlign = "left", this._axisCrossShape.style.textX = r + 10) : (this._axisCrossShape.style.textAlign = "right", this._axisCrossShape.style.textX = r - 10), s - this.component.grid.getY() > 50 ? (this._axisCrossShape.style.textBaseline = "bottom", this._axisCrossShape.style.textY = s - 10) : (this._axisCrossShape.style.textBaseline = "top", this._axisCrossShape.style.textY = s + 10), this._axisCrossShape.invisible = !1, this.zr.modShape(this._axisCrossShape.id)
                } else
                    "shadow" === c && ((null == m.shadow.width || "auto" === m.shadow.width || isNaN(m.shadow.width)) && (m.shadow.width = o), t === n ? Math.abs(this.component.grid.getX() - t) < 2 ? (m.shadow.width /= 2, t = n += m.shadow.width / 2) : Math.abs(this.component.grid.getXend() - t) < 2 && (m.shadow.width /= 2, t = n -= m.shadow.width / 2) : i === a && (Math.abs(this.component.grid.getY() - i) < 2 ? (m.shadow.width /= 2, i = a += m.shadow.width / 2) : Math.abs(this.component.grid.getYend() - i) < 2 && (m.shadow.width /= 2, i = a -= m.shadow.width / 2)), this._axisShadowShape.style = {xStart: t,yStart: i,xEnd: n,yEnd: a,strokeColor: m.shadow.color,lineWidth: m.shadow.width}, this._axisShadowShape.invisible = !1, this.zr.modShape(this._axisShadowShape.id));
                this.zr.refreshNextFrame()
            }
        },__onmousemove: function(e) {
            if (clearTimeout(this._hidingTicket), clearTimeout(this._showingTicket), !this._mousein || !this._enterable) {
                var t = e.target, i = d.getX(e.event), n = d.getY(e.event);
                if (t) {
                    this._curTarget = t, this._event = e.event, this._event.zrenderX = i, this._event.zrenderY = n;
                    var a;
                    if (this._needAxisTrigger && this.component.polar && -1 != (a = this.component.polar.isInside([i, n])))
                        for (var o = this.option.series, l = 0, h = o.length; h > l; l++)
                            if (o[l].polarIndex === a && "axis" === this.deepQuery([o[l], this.option], "tooltip.trigger")) {
                                this._curTarget = null;
                                break
                            }
                    this._showingTicket = setTimeout(this._tryShow, this._showDelay)
                } else
                    this._curTarget = !1, this._event = e.event, this._event.zrenderX = i, this._event.zrenderY = n, this._needAxisTrigger && this.component.grid && c.isInside(r, this.component.grid.getArea(), i, n) ? this._showingTicket = setTimeout(this._tryShow, this._showDelay) : this._needAxisTrigger && this.component.polar && -1 != this.component.polar.isInside([i, n]) ? this._showingTicket = setTimeout(this._tryShow, this._showDelay) : (!this._event.connectTrigger && this.messageCenter.dispatch(s.EVENT.TOOLTIP_OUT_GRID, this._event, null, this.myChart), this._hidingTicket = setTimeout(this._hide, this._hideDelay))
            }
        },__onglobalout: function() {
            clearTimeout(this._hidingTicket), clearTimeout(this._showingTicket), this._hidingTicket = setTimeout(this._hide, this._hideDelay)
        },__setContent: function(e, t) {
            this._tDom && (e === this._curTicket && (this._tDom.innerHTML = t), setTimeout(this._refixed, 20))
        },ontooltipHover: function(e, t) {
            if (!this._lastTipShape || this._lastTipShape && this._lastTipShape.dataIndex != e.dataIndex) {
                this._lastTipShape && this._lastTipShape.tipShape.length > 0 && (this.zr.delShape(this._lastTipShape.tipShape), this.shapeList.length = 2);
                for (var i = 0, n = t.length; n > i; i++)
                    t[i].zlevel = this.getZlevelBase(), t[i].z = this.getZBase(), t[i].style = u.prototype.getHighlightStyle(t[i].style, t[i].highlightStyle), t[i].draggable = !1, t[i].hoverable = !1, t[i].clickable = !1, t[i].ondragend = null, t[i].ondragover = null, t[i].ondrop = null, this.shapeList.push(t[i]), this.zr.addShape(t[i]);
                this._lastTipShape = {dataIndex: e.dataIndex,tipShape: t}
            }
        },ondragend: function() {
            this._hide()
        },onlegendSelected: function(e) {
            this._selectedMap = e.selected
        },_setSelectedMap: function() {
            this._selectedMap = this.component.legend ? p.clone(this.component.legend.getSelectedMap()) : {}
        },_isSelected: function(e) {
            return null != this._selectedMap[e] ? this._selectedMap[e] : !0
        },showTip: function(e) {
            if (e) {
                var t, i = this.option.series;
                if (null != e.seriesIndex)
                    t = e.seriesIndex;
                else
                    for (var n = e.seriesName, a = 0, o = i.length; o > a; a++)
                        if (i[a].name === n) {
                            t = a;
                            break
                        }
                var r = i[t];
                if (null != r) {
                    var d = this.myChart.chart[r.type], c = "axis" === this.deepQuery([r, this.option], "tooltip.trigger");
                    if (d)
                        if (c) {
                            var m = e.dataIndex;
                            switch (d.type) {
                                case s.CHART_TYPE_LINE:
                                case s.CHART_TYPE_BAR:
                                case s.CHART_TYPE_K:
                                case s.CHART_TYPE_RADAR:
                                    if (null == this.component.polar || r.data[0].value.length <= m)
                                        return;
                                    var p = r.polarIndex || 0, u = this.component.polar.getVector(p, m, "max");
                                    this._event = {zrenderX: u[0],zrenderY: u[1]}, this._showPolarTrigger(p, m)
                            }
                        } else {
                            var V, U, g = d.shapeList;
                            switch (d.type) {
                                case s.CHART_TYPE_LINE:
                                case s.CHART_TYPE_BAR:
                                case s.CHART_TYPE_K:
                                case s.CHART_TYPE_TREEMAP:
                                case s.CHART_TYPE_SCATTER:
                                    for (var m = e.dataIndex, a = 0, o = g.length; o > a; a++)
                                        if (null == g[a]._mark && l.get(g[a], "seriesIndex") == t && l.get(g[a], "dataIndex") == m) {
                                            this._curTarget = g[a], V = g[a].style.x, U = d.type != s.CHART_TYPE_K ? g[a].style.y : g[a].style.y[0];
                                            break
                                        }
                                    break;
                                case s.CHART_TYPE_RADAR:
                                    for (var m = e.dataIndex, a = 0, o = g.length; o > a; a++)
                                        if ("polygon" === g[a].type && l.get(g[a], "seriesIndex") == t && l.get(g[a], "dataIndex") == m) {
                                            this._curTarget = g[a];
                                            var u = this.component.polar.getCenter(r.polarIndex || 0);
                                            V = u[0], U = u[1];
                                            break
                                        }
                                    break;
                                case s.CHART_TYPE_PIE:
                                    for (var f = e.name, a = 0, o = g.length; o > a; a++)
                                        if ("sector" === g[a].type && l.get(g[a], "seriesIndex") == t && l.get(g[a], "name") == f) {
                                            this._curTarget = g[a];
                                            var y = this._curTarget.style, b = (y.startAngle + y.endAngle) / 2 * Math.PI / 180;
                                            V = this._curTarget.style.x + Math.cos(b) * y.r / 1.5, U = this._curTarget.style.y - Math.sin(b) * y.r / 1.5;
                                            break
                                        }
                                    break;
                                case s.CHART_TYPE_MAP:
                                    for (var f = e.name, _ = r.mapType, a = 0, o = g.length; o > a; a++)
                                        if ("text" === g[a].type && g[a]._mapType === _ && g[a].style._name === f) {
                                            this._curTarget = g[a], V = this._curTarget.style.x + this._curTarget.position[0], U = this._curTarget.style.y + this._curTarget.position[1];
                                            break
                                        }
                                    break;
                                case s.CHART_TYPE_CHORD:
                                    for (var f = e.name, a = 0, o = g.length; o > a; a++)
                                        if ("sector" === g[a].type && l.get(g[a], "name") == f) {
                                            this._curTarget = g[a];
                                            var y = this._curTarget.style, b = (y.startAngle + y.endAngle) / 2 * Math.PI / 180;
                                            return V = this._curTarget.style.x + Math.cos(b) * (y.r - 2), U = this._curTarget.style.y - Math.sin(b) * (y.r - 2), void this.zr.trigger(h.EVENT.MOUSEMOVE, {zrenderX: V,zrenderY: U})
                                        }
                                    break;
                                case s.CHART_TYPE_FORCE:
                                    for (var f = e.name, a = 0, o = g.length; o > a; a++)
                                        if ("circle" === g[a].type && l.get(g[a], "name") == f) {
                                            this._curTarget = g[a], V = this._curTarget.position[0], U = this._curTarget.position[1];
                                            break
                                        }
                            }
                            null != V && null != U && (this._event = {zrenderX: V,zrenderY: U}, this.zr.addHoverShape(this._curTarget), this.zr.refreshHover(), this._showItemTrigger())
                        }
                }
            }
        },hideTip: function() {
            this._hide()
        },refresh: function(e) {
            if (this._zrHeight = this.zr.getHeight(), this._zrWidth = this.zr.getWidth(), this._lastTipShape && this._lastTipShape.tipShape.length > 0 && this.zr.delShape(this._lastTipShape.tipShape), this._lastTipShape = !1, this.shapeList.length = 2, this._lastDataIndex = -1, this._lastSeriesIndex = -1, this._lastItemTriggerId = -1, e) {
                this.option = e, this.option.tooltip = this.reformOption(this.option.tooltip), this.option.tooltip.textStyle = p.merge(this.option.tooltip.textStyle, this.ecTheme.textStyle), this._needAxisTrigger = !1, "axis" === this.option.tooltip.trigger && (this._needAxisTrigger = !0);
                for (var t = this.option.series, i = 0, n = t.length; n > i; i++)
                    if ("axis" === this.query(t[i], "tooltip.trigger")) {
                        this._needAxisTrigger = !0;
                        break
                    }
                this._showDelay = this.option.tooltip.showDelay, this._hideDelay = this.option.tooltip.hideDelay, this._defaultCssText = this._style(this.option.tooltip), this._setSelectedMap(), this._axisLineWidth = this.option.tooltip.axisPointer.lineStyle.width, this._enterable = this.option.tooltip.enterable, !this._enterable && this._tDom.className.indexOf(h.elementClassName) < 0 && (this._tDom.className += " " + h.elementClassName)
            }
            if (this.showing) {
                var a = this;
                setTimeout(function() {
                    a.zr.trigger(h.EVENT.MOUSEMOVE, a.zr.handler._event)
                }, 50)
            }
        },onbeforDispose: function() {
            this._lastTipShape && this._lastTipShape.tipShape.length > 0 && this.zr.delShape(this._lastTipShape.tipShape), clearTimeout(this._hidingTicket), clearTimeout(this._showingTicket), this.zr.un(h.EVENT.MOUSEMOVE, this._onmousemove), this.zr.un(h.EVENT.GLOBALOUT, this._onglobalout), this.hasAppend && this.dom.firstChild && this.dom.firstChild.removeChild(this._tDom), this._tDom = null
        },_encodeHTML: function(e) {
            return String(e).replace(/&/g, "&amp;").replace(/</g, "&lt;").replace(/>/g, "&gt;").replace(/"/g, "&quot;").replace(/'/g, "&#39;")
        }}, p.inherits(t, i), e("../component").define("tooltip", t), t
}), define("echarts/component/legend", ["require", "./base", "zrender/shape/Text", "zrender/shape/Rectangle", "zrender/shape/Sector", "../util/shape/Icon", "../util/shape/Candle", "../config", "zrender/tool/util", "zrender/tool/area", "../component"], function(e) {
    function t(e, t, n, a, o) {
        if (!this.query(a, "legend.data"))
            return void console.error("option.legend.data has not been defined.");
        i.call(this, e, t, n, a, o);
        var r = this;
        r._legendSelected = function(e) {
            r.__legendSelected(e)
        }, r._dispatchHoverLink = function(e) {
            return r.__dispatchHoverLink(e)
        }, this._colorIndex = 0, this._colorMap = {}, this._selectedMap = {}, this._hasDataMap = {}, this.refresh(a)
    }
    var i = e("./base"), n = e("zrender/shape/Text"), a = e("zrender/shape/Rectangle"), o = e("zrender/shape/Sector"), r = e("../util/shape/Icon"), s = e("../util/shape/Candle"), l = e("../config");
    l.legend = {zlevel: 0,z: 4,show: !0,orient: "horizontal",x: "center",y: "top",backgroundColor: "rgba(0,0,0,0)",borderColor: "#ccc",borderWidth: 0,padding: 5,itemGap: 10,itemWidth: 20,itemHeight: 14,textStyle: {color: "#333"},selectedMode: !0};
    var h = e("zrender/tool/util"), d = e("zrender/tool/area");
    t.prototype = {type: l.COMPONENT_TYPE_LEGEND,_buildShape: function() {
            if (this.legendOption.show) {
                this._itemGroupLocation = this._getItemGroupLocation(), this._buildBackground(), this._buildItem();
                for (var e = 0, t = this.shapeList.length; t > e; e++)
                    this.zr.addShape(this.shapeList[e])
            }
        },_buildItem: function() {
            var e, t, i, a, o, s, l, c, m = this.legendOption.data, p = m.length, u = this.legendOption.textStyle, V = this.zr.getWidth(), U = this.zr.getHeight(), g = this._itemGroupLocation.x, f = this._itemGroupLocation.y, y = this.legendOption.itemWidth, b = this.legendOption.itemHeight, _ = this.legendOption.itemGap;
            "vertical" === this.legendOption.orient && "right" === this.legendOption.x && (g = this._itemGroupLocation.x + this._itemGroupLocation.width - y);
            for (var x = 0; p > x; x++)
                o = h.merge(m[x].textStyle || {}, u), s = this.getFont(o), e = this._getName(m[x]), l = this._getFormatterName(e), "" !== e ? (t = m[x].icon || this._getSomethingByName(e).type, c = this.getColor(e), "horizontal" === this.legendOption.orient ? 200 > V - g && y + 5 + d.getTextWidth(l, s) + (x === p - 1 || "" === m[x + 1] ? 0 : _) >= V - g && (g = this._itemGroupLocation.x, f += b + _) : 200 > U - f && b + (x === p - 1 || "" === m[x + 1] ? 0 : _) >= U - f && ("right" === this.legendOption.x ? g -= this._itemGroupLocation.maxWidth + _ : g += this._itemGroupLocation.maxWidth + _, f = this._itemGroupLocation.y), i = this._getItemShapeByType(g, f, y, b, this._selectedMap[e] && this._hasDataMap[e] ? c : "#ccc", t, c), i._name = e, i = new r(i), a = {zlevel: this.getZlevelBase(),z: this.getZBase(),style: {x: g + y + 5,y: f + b / 2,color: this._selectedMap[e] ? "auto" === o.color ? c : o.color : "#ccc",text: l,textFont: s,textBaseline: "middle"},highlightStyle: {color: c,brushType: "fill"},hoverable: !!this.legendOption.selectedMode,clickable: !!this.legendOption.selectedMode}, "vertical" === this.legendOption.orient && "right" === this.legendOption.x && (a.style.x -= y + 10, a.style.textAlign = "right"), a._name = e, a = new n(a), this.legendOption.selectedMode && (i.onclick = a.onclick = this._legendSelected, i.onmouseover = a.onmouseover = this._dispatchHoverLink, i.hoverConnect = a.id, a.hoverConnect = i.id), this.shapeList.push(i), this.shapeList.push(a), "horizontal" === this.legendOption.orient ? g += y + 5 + d.getTextWidth(l, s) + _ : f += b + _) : "horizontal" === this.legendOption.orient ? (g = this._itemGroupLocation.x, 
                f += b + _) : ("right" === this.legendOption.x ? g -= this._itemGroupLocation.maxWidth + _ : g += this._itemGroupLocation.maxWidth + _, f = this._itemGroupLocation.y);
            "horizontal" === this.legendOption.orient && "center" === this.legendOption.x && f != this._itemGroupLocation.y && this._mLineOptimize()
        },_getName: function(e) {
            return "undefined" != typeof e.name ? e.name : e
        },_getFormatterName: function(e) {
            var t, i = this.legendOption.formatter;
            return t = "function" == typeof i ? i.call(this.myChart, e) : "string" == typeof i ? i.replace("{name}", e) : e
        },_getFormatterNameFromData: function(e) {
            var t = this._getName(e);
            return this._getFormatterName(t)
        },_mLineOptimize: function() {
            for (var e = [], t = this._itemGroupLocation.x, i = 2, n = this.shapeList.length; n > i; i++)
                this.shapeList[i].style.x === t ? e.push((this._itemGroupLocation.width - (this.shapeList[i - 1].style.x + d.getTextWidth(this.shapeList[i - 1].style.text, this.shapeList[i - 1].style.textFont) - t)) / 2) : i === n - 1 && e.push((this._itemGroupLocation.width - (this.shapeList[i].style.x + d.getTextWidth(this.shapeList[i].style.text, this.shapeList[i].style.textFont) - t)) / 2);
            for (var a = -1, i = 1, n = this.shapeList.length; n > i; i++)
                this.shapeList[i].style.x === t && a++, 0 !== e[a] && (this.shapeList[i].style.x += e[a])
        },_buildBackground: function() {
            var e = this.reformCssArray(this.legendOption.padding);
            this.shapeList.push(new a({zlevel: this.getZlevelBase(),z: this.getZBase(),hoverable: !1,style: {x: this._itemGroupLocation.x - e[3],y: this._itemGroupLocation.y - e[0],width: this._itemGroupLocation.width + e[3] + e[1],height: this._itemGroupLocation.height + e[0] + e[2],brushType: 0 === this.legendOption.borderWidth ? "fill" : "both",color: this.legendOption.backgroundColor,strokeColor: this.legendOption.borderColor,lineWidth: this.legendOption.borderWidth}}))
        },_getItemGroupLocation: function() {
            var e = this.legendOption.data, t = e.length, i = this.legendOption.itemGap, n = this.legendOption.itemWidth + 5, a = this.legendOption.itemHeight, o = this.legendOption.textStyle, r = this.getFont(o), s = 0, l = 0, c = this.reformCssArray(this.legendOption.padding), m = this.zr.getWidth() - c[1] - c[3], p = this.zr.getHeight() - c[0] - c[2], u = 0, V = 0;
            if ("horizontal" === this.legendOption.orient) {
                l = a;
                for (var U = 0; t > U; U++)
                    if ("" !== this._getName(e[U])) {
                        var g = d.getTextWidth(this._getFormatterNameFromData(e[U]), e[U].textStyle ? this.getFont(h.merge(e[U].textStyle || {}, o)) : r);
                        u + n + g + i > m ? (u -= i, s = Math.max(s, u), l += a + i, u = 0) : (u += n + g + i, s = Math.max(s, u - i))
                    } else
                        u -= i, s = Math.max(s, u), l += a + i, u = 0
            } else {
                for (var U = 0; t > U; U++)
                    V = Math.max(V, d.getTextWidth(this._getFormatterNameFromData(e[U]), e[U].textStyle ? this.getFont(h.merge(e[U].textStyle || {}, o)) : r));
                V += n, s = V;
                for (var U = 0; t > U; U++)
                    "" !== this._getName(e[U]) ? u + a + i > p ? (s += V + i, u -= i, l = Math.max(l, u), u = 0) : (u += a + i, l = Math.max(l, u - i)) : (s += V + i, u -= i, l = Math.max(l, u), u = 0)
            }
            m = this.zr.getWidth(), p = this.zr.getHeight();
            var f;
            switch (this.legendOption.x) {
                case "center":
                    f = Math.floor((m - s) / 2);
                    break;
                case "left":
                    f = c[3] + this.legendOption.borderWidth;
                    break;
                case "right":
                    f = m - s - c[1] - c[3] - 2 * this.legendOption.borderWidth;
                    break;
                default:
                    f = this.parsePercent(this.legendOption.x, m)
            }
            var y;
            switch (this.legendOption.y) {
                case "top":
                    y = c[0] + this.legendOption.borderWidth;
                    break;
                case "bottom":
                    y = p - l - c[0] - c[2] - 2 * this.legendOption.borderWidth;
                    break;
                case "center":
                    y = Math.floor((p - l) / 2);
                    break;
                default:
                    y = this.parsePercent(this.legendOption.y, p)
            }
            return {x: f,y: y,width: s,height: l,maxWidth: V}
        },_getSomethingByName: function(e) {
            for (var t, i = this.option.series, n = 0, a = i.length; a > n; n++) {
                if (i[n].name === e)
                    return {type: i[n].type,series: i[n],seriesIndex: n,data: null,dataIndex: -1};
                if (i[n].type === l.CHART_TYPE_PIE || i[n].type === l.CHART_TYPE_RADAR || i[n].type === l.CHART_TYPE_CHORD || i[n].type === l.CHART_TYPE_FORCE || i[n].type === l.CHART_TYPE_FUNNEL || i[n].type === l.CHART_TYPE_TREEMAP) {
                    t = i[n].categories || i[n].data || i[n].nodes;
                    for (var o = 0, r = t.length; r > o; o++)
                        if (t[o].name === e)
                            return {type: i[n].type,series: i[n],seriesIndex: n,data: t[o],dataIndex: o}
                }
            }
            return {type: "bar",series: null,seriesIndex: -1,data: null,dataIndex: -1}
        },_getItemShapeByType: function(e, t, i, n, a, o, r) {
            var s, h = "#ccc" === a ? r : a, d = {zlevel: this.getZlevelBase(),z: this.getZBase(),style: {iconType: "legendicon" + o,x: e,y: t,width: i,height: n,color: a,strokeColor: a,lineWidth: 2},highlightStyle: {color: h,strokeColor: h,lineWidth: 1},hoverable: this.legendOption.selectedMode,clickable: this.legendOption.selectedMode};
            if (o.match("image")) {
                var s = o.replace(new RegExp("^image:\\/\\/"), "");
                o = "image"
            }
            switch (o) {
                case "line":
                    d.style.brushType = "stroke", d.highlightStyle.lineWidth = 3;
                    break;
                case "radar":
                case "venn":
                case "tree":
                case "treemap":
                case "scatter":
                    d.highlightStyle.lineWidth = 3;
                    break;
                case "k":
                    d.style.brushType = "both", d.highlightStyle.lineWidth = 3, d.highlightStyle.color = d.style.color = this.deepQuery([this.ecTheme, l], "k.itemStyle.normal.color") || "#fff", d.style.strokeColor = "#ccc" != a ? this.deepQuery([this.ecTheme, l], "k.itemStyle.normal.lineStyle.color") || "#ff3200" : a;
                    break;
                case "image":
                    d.style.iconType = "image", d.style.image = s, "#ccc" === a && (d.style.opacity = .5)
            }
            return d
        },__legendSelected: function(e) {
            var t = e.target._name;
            if ("single" === this.legendOption.selectedMode)
                for (var i in this._selectedMap)
                    this._selectedMap[i] = !1;
            this._selectedMap[t] = !this._selectedMap[t], this.messageCenter.dispatch(l.EVENT.LEGEND_SELECTED, e.event, {selected: this._selectedMap,target: t}, this.myChart)
        },__dispatchHoverLink: function(e) {
            this.messageCenter.dispatch(l.EVENT.LEGEND_HOVERLINK, e.event, {target: e.target._name}, this.myChart)
        },refresh: function(e) {
            if (e) {
                this.option = e || this.option, this.option.legend = this.reformOption(this.option.legend), this.legendOption = this.option.legend;
                var t, i, n, a, o = this.legendOption.data || [];
                if (this.legendOption.selected)
                    for (var r in this.legendOption.selected)
                        this._selectedMap[r] = "undefined" != typeof this._selectedMap[r] ? this._selectedMap[r] : this.legendOption.selected[r];
                for (var s = 0, h = o.length; h > s; s++)
                    t = this._getName(o[s]), "" !== t && (i = this._getSomethingByName(t), i.series ? (this._hasDataMap[t] = !0, a = !i.data || i.type !== l.CHART_TYPE_PIE && i.type !== l.CHART_TYPE_FORCE && i.type !== l.CHART_TYPE_FUNNEL ? [i.series] : [i.data, i.series], n = this.getItemStyleColor(this.deepQuery(a, "itemStyle.normal.color"), i.seriesIndex, i.dataIndex, i.data), n && i.type != l.CHART_TYPE_K && this.setColor(t, n), this._selectedMap[t] = null != this._selectedMap[t] ? this._selectedMap[t] : !0) : this._hasDataMap[t] = !1)
            }
            this.clear(), this._buildShape()
        },getRelatedAmount: function(e) {
            for (var t, i = 0, n = this.option.series, a = 0, o = n.length; o > a; a++)
                if (n[a].name === e && i++, n[a].type === l.CHART_TYPE_PIE || n[a].type === l.CHART_TYPE_RADAR || n[a].type === l.CHART_TYPE_CHORD || n[a].type === l.CHART_TYPE_FORCE || n[a].type === l.CHART_TYPE_FUNNEL) {
                    t = n[a].type != l.CHART_TYPE_FORCE ? n[a].data : n[a].categories;
                    for (var r = 0, s = t.length; s > r; r++)
                        t[r].name === e && "-" != t[r].value && i++
                }
            return i
        },setColor: function(e, t) {
            this._colorMap[e] = t
        },getColor: function(e) {
            return this._colorMap[e] || (this._colorMap[e] = this.zr.getColor(this._colorIndex++)), this._colorMap[e]
        },hasColor: function(e) {
            return this._colorMap[e] ? this._colorMap[e] : !1
        },add: function(e, t) {
            for (var i = this.legendOption.data, n = 0, a = i.length; a > n; n++)
                if (this._getName(i[n]) === e)
                    return;
            this.legendOption.data.push(e), this.setColor(e, t), this._selectedMap[e] = !0, this._hasDataMap[e] = !0
        },del: function(e) {
            for (var t = this.legendOption.data, i = 0, n = t.length; n > i; i++)
                if (this._getName(t[i]) === e)
                    return this.legendOption.data.splice(i, 1)
        },getItemShape: function(e) {
            if (null != e)
                for (var t, i = 0, n = this.shapeList.length; n > i; i++)
                    if (t = this.shapeList[i], t._name === e && "text" != t.type)
                        return t
        },setItemShape: function(e, t) {
            for (var i, n = 0, a = this.shapeList.length; a > n; n++)
                i = this.shapeList[n], i._name === e && "text" != i.type && (this._selectedMap[e] || (t.style.color = "#ccc", t.style.strokeColor = "#ccc"), this.zr.modShape(i.id, t))
        },isSelected: function(e) {
            return "undefined" != typeof this._selectedMap[e] ? this._selectedMap[e] : !0
        },getSelectedMap: function() {
            return this._selectedMap
        },setSelected: function(e, t) {
            if ("single" === this.legendOption.selectedMode)
                for (var i in this._selectedMap)
                    this._selectedMap[i] = !1;
            this._selectedMap[e] = t, this.messageCenter.dispatch(l.EVENT.LEGEND_SELECTED, null, {selected: this._selectedMap,target: e}, this.myChart)
        },onlegendSelected: function(e, t) {
            var i = e.selected;
            for (var n in i)
                this._selectedMap[n] != i[n] && (t.needRefresh = !0), this._selectedMap[n] = i[n]
        }};
    var c = {line: function(e, t) {
            var i = t.height / 2;
            e.moveTo(t.x, t.y + i), e.lineTo(t.x + t.width, t.y + i)
        },pie: function(e, t) {
            var i = t.x, n = t.y, a = t.width, r = t.height;
            o.prototype.buildPath(e, {x: i + a / 2,y: n + r + 2,r: r,r0: 6,startAngle: 45,endAngle: 135})
        },eventRiver: function(e, t) {
            var i = t.x, n = t.y, a = t.width, o = t.height;
            e.moveTo(i, n + o), e.bezierCurveTo(i + a, n + o, i, n + 4, i + a, n + 4), e.lineTo(i + a, n), e.bezierCurveTo(i, n, i + a, n + o - 4, i, n + o - 4), e.lineTo(i, n + o)
        },k: function(e, t) {
            var i = t.x, n = t.y, a = t.width, o = t.height;
            s.prototype.buildPath(e, {x: i + a / 2,y: [n + 1, n + 1, n + o - 6, n + o],width: a - 6})
        },bar: function(e, t) {
            var i = t.x, n = t.y + 1, a = t.width, o = t.height - 2, r = 3;
            e.moveTo(i + r, n), e.lineTo(i + a - r, n), e.quadraticCurveTo(i + a, n, i + a, n + r), e.lineTo(i + a, n + o - r), e.quadraticCurveTo(i + a, n + o, i + a - r, n + o), e.lineTo(i + r, n + o), e.quadraticCurveTo(i, n + o, i, n + o - r), e.lineTo(i, n + r), e.quadraticCurveTo(i, n, i + r, n)
        },force: function(e, t) {
            r.prototype.iconLibrary.circle(e, t)
        },radar: function(e, t) {
            var i = 6, n = t.x + t.width / 2, a = t.y + t.height / 2, o = t.height / 2, r = 2 * Math.PI / i, s = -Math.PI / 2, l = n + o * Math.cos(s), h = a + o * Math.sin(s);
            e.moveTo(l, h), s += r;
            for (var d = 0, c = i - 1; c > d; d++)
                e.lineTo(n + o * Math.cos(s), a + o * Math.sin(s)), s += r;
            e.lineTo(l, h)
        }};
    c.chord = c.pie, c.map = c.bar;
    for (var m in c)
        r.prototype.iconLibrary["legendicon" + m] = c[m];
    return h.inherits(t, i), e("../component").define("legend", t), t
}), define("echarts/util/ecData", [], function() {
    function e(e, t, i, n, a, o, r, s) {
        var l;
        return "undefined" != typeof n && (l = null == n.value ? n : n.value), e._echartsData = {_series: t,_seriesIndex: i,_data: n,_dataIndex: a,_name: o,_value: l,_special: r,_special2: s}, e._echartsData
    }
    function t(e, t) {
        var i = e._echartsData;
        if (!t)
            return i;
        switch (t) {
            case "series":
            case "seriesIndex":
            case "data":
            case "dataIndex":
            case "name":
            case "value":
            case "special":
            case "special2":
                return i && i["_" + t]
        }
        return null
    }
    function i(e, t, i) {
        switch (e._echartsData = e._echartsData || {}, t) {
            case "series":
            case "seriesIndex":
            case "data":
            case "dataIndex":
            case "name":
            case "value":
            case "special":
            case "special2":
                e._echartsData["_" + t] = i
        }
    }
    function n(e, t) {
        t._echartsData = {_series: e._echartsData._series,_seriesIndex: e._echartsData._seriesIndex,_data: e._echartsData._data,_dataIndex: e._echartsData._dataIndex,_name: e._echartsData._name,_value: e._echartsData._value,_special: e._echartsData._special,_special2: e._echartsData._special2}
    }
    return {pack: e,set: i,get: t,clone: n}
}), define("echarts/chart", [], function() {
    var e = {}, t = {};
    return e.define = function(i, n) {
        return t[i] = n, e
    }, e.get = function(e) {
        return t[e]
    }, e
}), define("zrender/tool/color", ["require", "../tool/util"], function(e) {
    function t(e) {
        D = e
    }
    function i() {
        D = N
    }
    function n(e, t) {
        return e = 0 | e, t = t || D, t[e % t.length]
    }
    function a(e) {
        B = e
    }
    function o() {
        H = B
    }
    function r() {
        return B
    }
    function s(e, t, i, n, a, o, r) {
        O || (O = P.getContext());
        for (var s = O.createRadialGradient(e, t, i, n, a, o), l = 0, h = r.length; h > l; l++)
            s.addColorStop(r[l][0], r[l][1]);
        return s.__nonRecursion = !0, s
    }
    function l(e, t, i, n, a) {
        O || (O = P.getContext());
        for (var o = O.createLinearGradient(e, t, i, n), r = 0, s = a.length; s > r; r++)
            o.addColorStop(a[r][0], a[r][1]);
        return o.__nonRecursion = !0, o
    }
    function h(e, t, i) {
        e = u(e), t = u(t), e = S(e), t = S(t);
        for (var n = [], a = (t[0] - e[0]) / i, o = (t[1] - e[1]) / i, r = (t[2] - e[2]) / i, s = (t[3] - e[3]) / i, l = 0, h = e[0], d = e[1], m = e[2], p = e[3]; i > l; l++)
            n[l] = c([T(Math.floor(h), [0, 255]), T(Math.floor(d), [0, 255]), T(Math.floor(m), [0, 255]), p.toFixed(4) - 0], "rgba"), h += a, d += o, m += r, p += s;
        return h = t[0], d = t[1], m = t[2], p = t[3], n[l] = c([h, d, m, p], "rgba"), n
    }
    function d(e, t) {
        var i = [], n = e.length;
        if (void 0 === t && (t = 20), 1 === n)
            i = h(e[0], e[0], t);
        else if (n > 1)
            for (var a = 0, o = n - 1; o > a; a++) {
                var r = h(e[a], e[a + 1], t);
                o - 1 > a && r.pop(), i = i.concat(r)
            }
        return i
    }
    function c(e, t) {
        if (t = t || "rgb", e && (3 === e.length || 4 === e.length)) {
            if (e = C(e, function(e) {
                return e > 1 ? Math.ceil(e) : e
            }), t.indexOf("hex") > -1)
                return "#" + ((1 << 24) + (e[0] << 16) + (e[1] << 8) + +e[2]).toString(16).slice(1);
            if (t.indexOf("hs") > -1) {
                var i = C(e.slice(1, 3), function(e) {
                    return e + "%"
                });
                e[1] = i[0], e[2] = i[1]
            }
            return t.indexOf("a") > -1 ? (3 === e.length && e.push(1), e[3] = T(e[3], [0, 1]), t + "(" + e.slice(0, 4).join(",") + ")") : t + "(" + e.slice(0, 3).join(",") + ")"
        }
    }
    function m(e) {
        e = v(e), e.indexOf("rgba") < 0 && (e = u(e));
        var t = [], i = 0;
        return e.replace(/[\d.]+/g, function(e) {
            e = 3 > i ? 0 | e : +e, t[i++] = e
        }), t
    }
    function p(e, t) {
        if (!E(e))
            return e;
        var i = S(e), n = i[3];
        return "undefined" == typeof n && (n = 1), e.indexOf("hsb") > -1 ? i = z(i) : e.indexOf("hsl") > -1 && (i = A(i)), t.indexOf("hsb") > -1 || t.indexOf("hsv") > -1 ? i = F(i) : t.indexOf("hsl") > -1 && (i = J(i)), i[3] = n, c(i, t)
    }
    function u(e) {
        return p(e, "rgba")
    }
    function V(e) {
        return p(e, "rgb")
    }
    function U(e) {
        return p(e, "hex")
    }
    function g(e) {
        return p(e, "hsva")
    }
    function f(e) {
        return p(e, "hsv")
    }
    function y(e) {
        return p(e, "hsba")
    }
    function b(e) {
        return p(e, "hsb")
    }
    function _(e) {
        return p(e, "hsla")
    }
    function x(e) {
        return p(e, "hsl")
    }
    function k(e) {
        for (var t in G)
            if (U(G[t]) === U(e))
                return t;
        return null
    }
    function v(e) {
        return String(e).replace(/\s+/g, "")
    }
    function L(e) {
        if (G[e] && (e = G[e]), e = v(e), e = e.replace(/hsv/i, "hsb"), /^#[\da-f]{3}$/i.test(e)) {
            e = parseInt(e.slice(1), 16);
            var t = (3840 & e) << 8, i = (240 & e) << 4, n = 15 & e;
            e = "#" + ((1 << 24) + (t << 4) + t + (i << 4) + i + (n << 4) + n).toString(16).slice(1)
        }
        return e
    }
    function w(e, t) {
        if (!E(e))
            return e;
        var i = t > 0 ? 1 : -1;
        "undefined" == typeof t && (t = 0), t = Math.abs(t) > 1 ? 1 : Math.abs(t), e = V(e);
        for (var n = S(e), a = 0; 3 > a; a++)
            n[a] = 1 === i ? n[a] * (1 - t) | 0 : (255 - n[a]) * t + n[a] | 0;
        return "rgb(" + n.join(",") + ")"
    }
    function W(e) {
        if (!E(e))
            return e;
        var t = S(u(e));
        return t = C(t, function(e) {
            return 255 - e
        }), c(t, "rgb")
    }
    function X(e, t, i) {
        if (!E(e) || !E(t))
            return e;
        "undefined" == typeof i && (i = .5), i = 1 - T(i, [0, 1]);
        for (var n = 2 * i - 1, a = S(u(e)), o = S(u(t)), r = a[3] - o[3], s = ((n * r === -1 ? n : (n + r) / (1 + n * r)) + 1) / 2, l = 1 - s, h = [], d = 0; 3 > d; d++)
            h[d] = a[d] * s + o[d] * l;
        var m = a[3] * i + o[3] * (1 - i);
        return m = Math.max(0, Math.min(1, m)), 1 === a[3] && 1 === o[3] ? c(h, "rgb") : (h[3] = m, c(h, "rgba"))
    }
    function I() {
        return "#" + (Math.random().toString(16) + "0000").slice(2, 8)
    }
    function S(e) {
        e = L(e);
        var t = e.match(R);
        if (null === t)
            throw new Error("The color format error");
        var i, n, a, o = [];
        if (t[2])
            i = t[2].replace("#", "").split(""), a = [i[0] + i[1], i[2] + i[3], i[4] + i[5]], o = C(a, function(e) {
                return T(parseInt(e, 16), [0, 255])
            });
        else if (t[4]) {
            var r = t[4].split(",");
            n = r[3], a = r.slice(0, 3), o = C(a, function(e) {
                return e = Math.floor(e.indexOf("%") > 0 ? 2.55 * parseInt(e, 0) : e), T(e, [0, 255])
            }), "undefined" != typeof n && o.push(T(parseFloat(n), [0, 1]))
        } else if (t[5] || t[6]) {
            var s = (t[5] || t[6]).split(","), l = parseInt(s[0], 0) / 360, h = s[1], d = s[2];
            n = s[3], o = C([h, d], function(e) {
                return T(parseFloat(e) / 100, [0, 1])
            }), o.unshift(l), "undefined" != typeof n && o.push(T(parseFloat(n), [0, 1]))
        }
        return o
    }
    function K(e, t) {
        if (!E(e))
            return e;
        null === t && (t = 1);
        var i = S(u(e));
        return i[3] = T(Number(t).toFixed(4), [0, 1]), c(i, "rgba")
    }
    function C(e, t) {
        if ("function" != typeof t)
            throw new TypeError;
        for (var i = e ? e.length : 0, n = 0; i > n; n++)
            e[n] = t(e[n]);
        return e
    }
    function T(e, t) {
        return e <= t[0] ? e = t[0] : e >= t[1] && (e = t[1]), e
    }
    function E(e) {
        return e instanceof Array || "string" == typeof e
    }
    function z(e) {
        var t, i, n, a = e[0], o = e[1], r = e[2];
        if (0 === o)
            t = 255 * r, i = 255 * r, n = 255 * r;
        else {
            var s = 6 * a;
            6 === s && (s = 0);
            var l = 0 | s, h = r * (1 - o), d = r * (1 - o * (s - l)), c = r * (1 - o * (1 - (s - l))), m = 0, p = 0, u = 0;
            0 === l ? (m = r, p = c, u = h) : 1 === l ? (m = d, p = r, u = h) : 2 === l ? (m = h, p = r, u = c) : 3 === l ? (m = h, p = d, u = r) : 4 === l ? (m = c, p = h, u = r) : (m = r, p = h, u = d), t = 255 * m, i = 255 * p, n = 255 * u
        }
        return [t, i, n]
    }
    function A(e) {
        var t, i, n, a = e[0], o = e[1], r = e[2];
        if (0 === o)
            t = 255 * r, i = 255 * r, n = 255 * r;
        else {
            var s;
            s = .5 > r ? r * (1 + o) : r + o - o * r;
            var l = 2 * r - s;
            t = 255 * M(l, s, a + 1 / 3), i = 255 * M(l, s, a), n = 255 * M(l, s, a - 1 / 3)
        }
        return [t, i, n]
    }
    function M(e, t, i) {
        return 0 > i && (i += 1), i > 1 && (i -= 1), 1 > 6 * i ? e + 6 * (t - e) * i : 1 > 2 * i ? t : 2 > 3 * i ? e + (t - e) * (2 / 3 - i) * 6 : e
    }
    function F(e) {
        var t, i, n = e[0] / 255, a = e[1] / 255, o = e[2] / 255, r = Math.min(n, a, o), s = Math.max(n, a, o), l = s - r, h = s;
        if (0 === l)
            t = 0, i = 0;
        else {
            i = l / s;
            var d = ((s - n) / 6 + l / 2) / l, c = ((s - a) / 6 + l / 2) / l, m = ((s - o) / 6 + l / 2) / l;
            n === s ? t = m - c : a === s ? t = 1 / 3 + d - m : o === s && (t = 2 / 3 + c - d), 0 > t && (t += 1), t > 1 && (t -= 1)
        }
        return t = 360 * t, i = 100 * i, h = 100 * h, [t, i, h]
    }
    function J(e) {
        var t, i, n = e[0] / 255, a = e[1] / 255, o = e[2] / 255, r = Math.min(n, a, o), s = Math.max(n, a, o), l = s - r, h = (s + r) / 2;
        if (0 === l)
            t = 0, i = 0;
        else {
            i = .5 > h ? l / (s + r) : l / (2 - s - r);
            var d = ((s - n) / 6 + l / 2) / l, c = ((s - a) / 6 + l / 2) / l, m = ((s - o) / 6 + l / 2) / l;
            n === s ? t = m - c : a === s ? t = 1 / 3 + d - m : o === s && (t = 2 / 3 + c - d), 0 > t && (t += 1), t > 1 && (t -= 1)
        }
        return t = 360 * t, i = 100 * i, h = 100 * h, [t, i, h]
    }
    var O, P = e("../tool/util"), D = ["#ff9277", " #dddd00", " #ffc877", " #bbe3ff", " #d5ffbb", "#bbbbff", " #ddb000", " #b0dd00", " #e2bbff", " #ffbbe3", "#ff7777", " #ff9900", " #83dd00", " #77e3ff", " #778fff", "#c877ff", " #ff77ab", " #ff6600", " #aa8800", " #77c7ff", "#ad77ff", " #ff77ff", " #dd0083", " #777700", " #00aa00", "#0088aa", " #8400dd", " #aa0088", " #dd0000", " #772e00"], N = D, B = "rgba(255,255,0,0.5)", H = B, R = /^\s*((#[a-f\d]{6})|(#[a-f\d]{3})|rgba?\(\s*([\d\.]+%?\s*,\s*[\d\.]+%?\s*,\s*[\d\.]+%?(?:\s*,\s*[\d\.]+%?)?)\s*\)|hsba?\(\s*([\d\.]+(?:deg|\xb0|%)?\s*,\s*[\d\.]+%?\s*,\s*[\d\.]+%?(?:\s*,\s*[\d\.]+)?)%?\s*\)|hsla?\(\s*([\d\.]+(?:deg|\xb0|%)?\s*,\s*[\d\.]+%?\s*,\s*[\d\.]+%?(?:\s*,\s*[\d\.]+)?)%?\s*\))\s*$/i, G = {aliceblue: "#f0f8ff",antiquewhite: "#faebd7",aqua: "#0ff",aquamarine: "#7fffd4",azure: "#f0ffff",beige: "#f5f5dc",bisque: "#ffe4c4",black: "#000",blanchedalmond: "#ffebcd",blue: "#00f",blueviolet: "#8a2be2",brown: "#a52a2a",burlywood: "#deb887",cadetblue: "#5f9ea0",chartreuse: "#7fff00",chocolate: "#d2691e",coral: "#ff7f50",cornflowerblue: "#6495ed",cornsilk: "#fff8dc",crimson: "#dc143c",cyan: "#0ff",darkblue: "#00008b",darkcyan: "#008b8b",darkgoldenrod: "#b8860b",darkgray: "#a9a9a9",darkgrey: "#a9a9a9",darkgreen: "#006400",darkkhaki: "#bdb76b",darkmagenta: "#8b008b",darkolivegreen: "#556b2f",darkorange: "#ff8c00",darkorchid: "#9932cc",darkred: "#8b0000",darksalmon: "#e9967a",darkseagreen: "#8fbc8f",darkslateblue: "#483d8b",darkslategray: "#2f4f4f",darkslategrey: "#2f4f4f",darkturquoise: "#00ced1",darkviolet: "#9400d3",deeppink: "#ff1493",deepskyblue: "#00bfff",dimgray: "#696969",dimgrey: "#696969",dodgerblue: "#1e90ff",firebrick: "#b22222",floralwhite: "#fffaf0",forestgreen: "#228b22",fuchsia: "#f0f",gainsboro: "#dcdcdc",ghostwhite: "#f8f8ff",gold: "#ffd700",goldenrod: "#daa520",gray: "#808080",grey: "#808080",green: "#008000",greenyellow: "#adff2f",honeydew: "#f0fff0",hotpink: "#ff69b4",indianred: "#cd5c5c",indigo: "#4b0082",ivory: "#fffff0",khaki: "#f0e68c",lavender: "#e6e6fa",lavenderblush: "#fff0f5",lawngreen: "#7cfc00",lemonchiffon: "#fffacd",lightblue: "#add8e6",lightcoral: "#f08080",lightcyan: "#e0ffff",lightgoldenrodyellow: "#fafad2",lightgray: "#d3d3d3",lightgrey: "#d3d3d3",lightgreen: "#90ee90",lightpink: "#ffb6c1",lightsalmon: "#ffa07a",lightseagreen: "#20b2aa",lightskyblue: "#87cefa",lightslategray: "#789",lightslategrey: "#789",lightsteelblue: "#b0c4de",lightyellow: "#ffffe0",lime: "#0f0",limegreen: "#32cd32",linen: "#faf0e6",magenta: "#f0f",maroon: "#800000",mediumaquamarine: "#66cdaa",mediumblue: "#0000cd",mediumorchid: "#ba55d3",mediumpurple: "#9370d8",mediumseagreen: "#3cb371",mediumslateblue: "#7b68ee",mediumspringgreen: "#00fa9a",mediumturquoise: "#48d1cc",mediumvioletred: "#c71585",midnightblue: "#191970",mintcream: "#f5fffa",mistyrose: "#ffe4e1",moccasin: "#ffe4b5",navajowhite: "#ffdead",navy: "#000080",oldlace: "#fdf5e6",olive: "#808000",olivedrab: "#6b8e23",orange: "#ffa500",orangered: "#ff4500",orchid: "#da70d6",palegoldenrod: "#eee8aa",palegreen: "#98fb98",paleturquoise: "#afeeee",palevioletred: "#d87093",papayawhip: "#ffefd5",peachpuff: "#ffdab9",peru: "#cd853f",pink: "#ffc0cb",plum: "#dda0dd",powderblue: "#b0e0e6",purple: "#800080",red: "#f00",rosybrown: "#bc8f8f",royalblue: "#4169e1",saddlebrown: "#8b4513",salmon: "#fa8072",sandybrown: "#f4a460",seagreen: "#2e8b57",seashell: "#fff5ee",sienna: "#a0522d",silver: "#c0c0c0",skyblue: "#87ceeb",slateblue: "#6a5acd",slategray: "#708090",slategrey: "#708090",snow: "#fffafa",springgreen: "#00ff7f",steelblue: "#4682b4",tan: "#d2b48c",teal: "#008080",thistle: "#d8bfd8",tomato: "#ff6347",turquoise: "#40e0d0",violet: "#ee82ee",wheat: "#f5deb3",white: "#fff",whitesmoke: "#f5f5f5",yellow: "#ff0",yellowgreen: "#9acd32"};
    return {customPalette: t,resetPalette: i,getColor: n,getHighlightColor: r,customHighlight: a,resetHighlight: o,getRadialGradient: s,getLinearGradient: l,getGradientColors: d,getStepColors: h,reverse: W,mix: X,lift: w,trim: v,random: I,toRGB: V,toRGBA: u,toHex: U,toHSL: x,toHSLA: _,toHSB: b,toHSBA: y,toHSV: f,toHSVA: g,toName: k,toColor: c,toArray: m,alpha: K,getData: S}
}), define("echarts/component/timeline", ["require", "./base", "zrender/shape/Rectangle", "../util/shape/Icon", "../util/shape/Chain", "../config", "zrender/tool/util", "zrender/tool/area", "zrender/tool/event", "../component"], function(e) {
    function t(e, t, i, a, o) {
        n.call(this, e, t, i, a, o);
        var r = this;
        if (r._onclick = function(e) {
            return r.__onclick(e)
        }, r._ondrift = function(e, t) {
            return r.__ondrift(this, e, t)
        }, r._ondragend = function() {
            return r.__ondragend()
        }, r._setCurrentOption = function() {
            var e = r.timelineOption;
            r.currentIndex %= e.data.length;
            var t = r.options[r.currentIndex] || {};
            r.myChart._setOption(t, e.notMerge, !0), r.messageCenter.dispatch(s.EVENT.TIMELINE_CHANGED, null, {currentIndex: r.currentIndex,data: null != e.data[r.currentIndex].name ? e.data[r.currentIndex].name : e.data[r.currentIndex]}, r.myChart)
        }, r._onFrame = function() {
            r._setCurrentOption(), r._syncHandleShape(), r.timelineOption.autoPlay && (r.playTicket = setTimeout(function() {
                return r.currentIndex += 1, !r.timelineOption.loop && r.currentIndex >= r.timelineOption.data.length ? (r.currentIndex = r.timelineOption.data.length - 1, void r.stop()) : void r._onFrame()
            }, r.timelineOption.playInterval))
        }, this.setTheme(!1), this.options = this.option.options, this.currentIndex = this.timelineOption.currentIndex % this.timelineOption.data.length, this.timelineOption.notMerge || 0 === this.currentIndex || (this.options[this.currentIndex] = l.merge(this.options[this.currentIndex], this.options[0])), this.timelineOption.show && (this._buildShape(), this._syncHandleShape()), this._setCurrentOption(), this.timelineOption.autoPlay) {
            var r = this;
            this.playTicket = setTimeout(function() {
                r.play()
            }, null != this.ecTheme.animationDuration ? this.ecTheme.animationDuration : s.animationDuration)
        }
    }
    function i(e, t) {
        var i = 2, n = t.x + i, a = t.y + i + 2, r = t.width - i, s = t.height - i, l = t.symbol;
        if ("last" === l)
            e.moveTo(n + r - 2, a + s / 3), e.lineTo(n + r - 2, a), e.lineTo(n + 2, a + s / 2), e.lineTo(n + r - 2, a + s), e.lineTo(n + r - 2, a + s / 3 * 2), e.moveTo(n, a), e.lineTo(n, a);
        else if ("next" === l)
            e.moveTo(n + 2, a + s / 3), e.lineTo(n + 2, a), e.lineTo(n + r - 2, a + s / 2), e.lineTo(n + 2, a + s), e.lineTo(n + 2, a + s / 3 * 2), e.moveTo(n, a), e.lineTo(n, a);
        else if ("play" === l)
            if ("stop" === t.status)
                e.moveTo(n + 2, a), e.lineTo(n + r - 2, a + s / 2), e.lineTo(n + 2, a + s), e.lineTo(n + 2, a);
            else {
                var h = "both" === t.brushType ? 2 : 3;
                e.rect(n + 2, a, h, s), e.rect(n + r - h - 2, a, h, s)
            }
        else if (l.match("image")) {
            var d = "";
            d = l.replace(new RegExp("^image:\\/\\/"), ""), l = o.prototype.iconLibrary.image, l(e, {x: n,y: a,width: r,height: s,image: d})
        }
    }
    var n = e("./base"), a = e("zrender/shape/Rectangle"), o = e("../util/shape/Icon"), r = e("../util/shape/Chain"), s = e("../config");
    s.timeline = {zlevel: 0,z: 4,show: !0,type: "time",notMerge: !1,realtime: !0,x: 80,x2: 80,y2: 0,height: 50,backgroundColor: "rgba(0,0,0,0)",borderColor: "#ccc",borderWidth: 0,padding: 5,controlPosition: "left",autoPlay: !1,loop: !0,playInterval: 2e3,lineStyle: {width: 1,color: "#666",type: "dashed"},label: {show: !0,interval: "auto",rotate: 0,textStyle: {color: "#333"}},checkpointStyle: {symbol: "auto",symbolSize: "auto",color: "auto",borderColor: "auto",borderWidth: "auto",label: {show: !1,textStyle: {color: "auto"}}},controlStyle: {itemSize: 15,itemGap: 5,normal: {color: "#333"},emphasis: {color: "#1e90ff"}},symbol: "emptyDiamond",symbolSize: 4,currentIndex: 0};
    var l = e("zrender/tool/util"), h = e("zrender/tool/area"), d = e("zrender/tool/event");
    return t.prototype = {type: s.COMPONENT_TYPE_TIMELINE,_buildShape: function() {
            if (this._location = this._getLocation(), this._buildBackground(), this._buildControl(), this._chainPoint = this._getChainPoint(), this.timelineOption.label.show)
                for (var e = this._getInterval(), t = 0, i = this._chainPoint.length; i > t; t += e)
                    this._chainPoint[t].showLabel = !0;
            this._buildChain(), this._buildHandle();
            for (var t = 0, n = this.shapeList.length; n > t; t++)
                this.zr.addShape(this.shapeList[t])
        },_getLocation: function() {
            var e, t = this.timelineOption, i = this.reformCssArray(this.timelineOption.padding), n = this.zr.getWidth(), a = this.parsePercent(t.x, n), o = this.parsePercent(t.x2, n);
            null == t.width ? (e = n - a - o, o = n - o) : (e = this.parsePercent(t.width, n), o = a + e);
            var r, s, l = this.zr.getHeight(), h = this.parsePercent(t.height, l);
            return null != t.y ? (r = this.parsePercent(t.y, l), s = r + h) : (s = l - this.parsePercent(t.y2, l), r = s - h), {x: a + i[3],y: r + i[0],x2: o - i[1],y2: s - i[2],width: e - i[1] - i[3],height: h - i[0] - i[2]}
        },_getReformedLabel: function(e) {
            var t = this.timelineOption, i = null != t.data[e].name ? t.data[e].name : t.data[e], n = t.data[e].formatter || t.label.formatter;
            return n && ("function" == typeof n ? i = n.call(this.myChart, i) : "string" == typeof n && (i = n.replace("{value}", i))), i
        },_getInterval: function() {
            var e = this._chainPoint, t = this.timelineOption, i = t.label.interval;
            if ("auto" === i) {
                var n = t.label.textStyle.fontSize, a = t.data, o = t.data.length;
                if (o > 3) {
                    var r, s, l = !1;
                    for (i = 0; !l && o > i; ) {
                        i++, l = !0;
                        for (var d = i; o > d; d += i) {
                            if (r = e[d].x - e[d - i].x, 0 !== t.label.rotate)
                                s = n;
                            else if (a[d].textStyle)
                                s = h.getTextWidth(e[d].name, e[d].textFont);
                            else {
                                var c = e[d].name + "", m = (c.match(/\w/g) || "").length, p = c.length - m;
                                s = m * n * 2 / 3 + p * n
                            }
                            if (s > r) {
                                l = !1;
                                break
                            }
                        }
                    }
                } else
                    i = 1
            } else
                i = i - 0 + 1;
            return i
        },_getChainPoint: function() {
            function e(e) {
                return null != h[e].name ? h[e].name : h[e] + ""
            }
            var t, i = this.timelineOption, n = i.symbol.toLowerCase(), a = i.symbolSize, o = i.label.rotate, r = i.label.textStyle, s = this.getFont(r), h = i.data, d = this._location.x, c = this._location.y + this._location.height / 4 * 3, m = this._location.x2 - this._location.x, p = h.length, u = [];
            if (p > 1) {
                var V = m / p;
                if (V = V > 50 ? 50 : 20 > V ? 5 : V, m -= 2 * V, "number" === i.type)
                    for (var U = 0; p > U; U++)
                        u.push(d + V + m / (p - 1) * U);
                else {
                    u[0] = new Date(e(0).replace(/-/g, "/")), u[p - 1] = new Date(e(p - 1).replace(/-/g, "/")) - u[0];
                    for (var U = 1; p > U; U++)
                        u[U] = d + V + m * (new Date(e(U).replace(/-/g, "/")) - u[0]) / u[p - 1];
                    u[0] = d + V
                }
            } else
                u.push(d + m / 2);
            for (var g, f, y, b, _, x = [], U = 0; p > U; U++)
                d = u[U], g = h[U].symbol && h[U].symbol.toLowerCase() || n, g.match("empty") ? (g = g.replace("empty", ""), y = !0) : y = !1, g.match("star") && (f = g.replace("star", "") - 0 || 5, g = "star"), t = h[U].textStyle ? l.merge(h[U].textStyle || {}, r) : r, b = t.align || "center", o ? (b = o > 0 ? "right" : "left", _ = [o * Math.PI / 180, d, c - 5]) : _ = !1, x.push({x: d,n: f,isEmpty: y,symbol: g,symbolSize: h[U].symbolSize || a,color: h[U].color,borderColor: h[U].borderColor,borderWidth: h[U].borderWidth,name: this._getReformedLabel(U),textColor: t.color,textAlign: b,textBaseline: t.baseline || "middle",textX: d,textY: c - (o ? 5 : 0),textFont: h[U].textStyle ? this.getFont(t) : s,rotation: _,showLabel: !1});
            return x
        },_buildBackground: function() {
            var e = this.timelineOption, t = this.reformCssArray(this.timelineOption.padding), i = this._location.width, n = this._location.height;
            (0 !== e.borderWidth || "rgba(0,0,0,0)" != e.backgroundColor.replace(/\s/g, "")) && this.shapeList.push(new a({zlevel: this.getZlevelBase(),z: this.getZBase(),hoverable: !1,style: {x: this._location.x - t[3],y: this._location.y - t[0],width: i + t[1] + t[3],height: n + t[0] + t[2],brushType: 0 === e.borderWidth ? "fill" : "both",color: e.backgroundColor,strokeColor: e.borderColor,lineWidth: e.borderWidth}}))
        },_buildControl: function() {
            var e = this, t = this.timelineOption, i = t.lineStyle, n = t.controlStyle;
            if ("none" !== t.controlPosition) {
                var a, r = n.itemSize, s = n.itemGap;
                "left" === t.controlPosition ? (a = this._location.x, this._location.x += 3 * (r + s)) : (a = this._location.x2 - (3 * (r + s) - s), this._location.x2 -= 3 * (r + s));
                var h = this._location.y, d = {zlevel: this.getZlevelBase(),z: this.getZBase() + 1,style: {iconType: "timelineControl",symbol: "last",x: a,y: h,width: r,height: r,brushType: "stroke",color: n.normal.color,strokeColor: n.normal.color,lineWidth: i.width},highlightStyle: {color: n.emphasis.color,strokeColor: n.emphasis.color,lineWidth: i.width + 1},clickable: !0};
                this._ctrLastShape = new o(d), this._ctrLastShape.onclick = function() {
                    e.last()
                }, this.shapeList.push(this._ctrLastShape), a += r + s, this._ctrPlayShape = new o(l.clone(d)), this._ctrPlayShape.style.brushType = "fill", this._ctrPlayShape.style.symbol = "play", this._ctrPlayShape.style.status = this.timelineOption.autoPlay ? "playing" : "stop", this._ctrPlayShape.style.x = a, this._ctrPlayShape.onclick = function() {
                    "stop" === e._ctrPlayShape.style.status ? e.play() : e.stop()
                }, this.shapeList.push(this._ctrPlayShape), a += r + s, this._ctrNextShape = new o(l.clone(d)), this._ctrNextShape.style.symbol = "next", this._ctrNextShape.style.x = a, this._ctrNextShape.onclick = function() {
                    e.next()
                }, this.shapeList.push(this._ctrNextShape)
            }
        },_buildChain: function() {
            var e = this.timelineOption, t = e.lineStyle;
            this._timelineShae = {zlevel: this.getZlevelBase(),z: this.getZBase(),style: {x: this._location.x,y: this.subPixelOptimize(this._location.y, t.width),width: this._location.x2 - this._location.x,height: this._location.height,chainPoint: this._chainPoint,brushType: "both",strokeColor: t.color,lineWidth: t.width,lineType: t.type},hoverable: !1,clickable: !0,onclick: this._onclick}, this._timelineShae = new r(this._timelineShae), this.shapeList.push(this._timelineShae)
        },_buildHandle: function() {
            var e = this._chainPoint[this.currentIndex], t = e.symbolSize + 1;
            t = 5 > t ? 5 : t, this._handleShape = {zlevel: this.getZlevelBase(),z: this.getZBase() + 1,hoverable: !1,draggable: !0,style: {iconType: "diamond",n: e.n,x: e.x - t,y: this._location.y + this._location.height / 4 - t,width: 2 * t,height: 2 * t,brushType: "both",textPosition: "specific",textX: e.x,textY: this._location.y - this._location.height / 4,textAlign: "center",textBaseline: "middle"},highlightStyle: {},ondrift: this._ondrift,ondragend: this._ondragend}, this._handleShape = new o(this._handleShape), this.shapeList.push(this._handleShape)
        },_syncHandleShape: function() {
            if (this.timelineOption.show) {
                var e = this.timelineOption, t = e.checkpointStyle, i = this._chainPoint[this.currentIndex];
                this._handleShape.style.text = t.label.show ? i.name : "", this._handleShape.style.textFont = i.textFont, this._handleShape.style.n = i.n, "auto" === t.symbol ? this._handleShape.style.iconType = "none" != i.symbol ? i.symbol : "diamond" : (this._handleShape.style.iconType = t.symbol, t.symbol.match("star") && (this._handleShape.style.n = t.symbol.replace("star", "") - 0 || 5, this._handleShape.style.iconType = "star"));
                var n;
                "auto" === t.symbolSize ? (n = i.symbolSize + 2, n = 5 > n ? 5 : n) : n = t.symbolSize - 0, this._handleShape.style.color = "auto" === t.color ? i.color ? i.color : e.controlStyle.emphasis.color : t.color, this._handleShape.style.textColor = "auto" === t.label.textStyle.color ? this._handleShape.style.color : t.label.textStyle.color, this._handleShape.highlightStyle.strokeColor = this._handleShape.style.strokeColor = "auto" === t.borderColor ? i.borderColor ? i.borderColor : "#fff" : t.borderColor, this._handleShape.style.lineWidth = "auto" === t.borderWidth ? i.borderWidth ? i.borderWidth : 0 : t.borderWidth - 0, this._handleShape.highlightStyle.lineWidth = this._handleShape.style.lineWidth + 1, this.zr.animate(this._handleShape.id, "style").when(500, {x: i.x - n,textX: i.x,y: this._location.y + this._location.height / 4 - n,width: 2 * n,height: 2 * n}).start("ExponentialOut")
            }
        },_findChainIndex: function(e) {
            var t = this._chainPoint, i = t.length;
            if (e <= t[0].x)
                return 0;
            if (e >= t[i - 1].x)
                return i - 1;
            for (var n = 0; i - 1 > n; n++)
                if (e >= t[n].x && e <= t[n + 1].x)
                    return Math.abs(e - t[n].x) < Math.abs(e - t[n + 1].x) ? n : n + 1
        },__onclick: function(e) {
            var t = d.getX(e.event), i = this._findChainIndex(t);
            return i === this.currentIndex ? !0 : (this.currentIndex = i, this.timelineOption.autoPlay && this.stop(), clearTimeout(this.playTicket), void this._onFrame())
        },__ondrift: function(e, t) {
            this.timelineOption.autoPlay && this.stop();
            var i, n = this._chainPoint, a = n.length;
            e.style.x + t <= n[0].x - n[0].symbolSize ? (e.style.x = n[0].x - n[0].symbolSize, i = 0) : e.style.x + t >= n[a - 1].x - n[a - 1].symbolSize ? (e.style.x = n[a - 1].x - n[a - 1].symbolSize, i = a - 1) : (e.style.x += t, i = this._findChainIndex(e.style.x));
            var o = n[i], r = o.symbolSize + 2;
            if (e.style.iconType = o.symbol, e.style.n = o.n, e.style.textX = e.style.x + r / 2, e.style.y = this._location.y + this._location.height / 4 - r, e.style.width = 2 * r, e.style.height = 2 * r, e.style.text = o.name, i === this.currentIndex)
                return !0;
            if (this.currentIndex = i, this.timelineOption.realtime) {
                clearTimeout(this.playTicket);
                var s = this;
                this.playTicket = setTimeout(function() {
                    s._setCurrentOption()
                }, 200)
            }
            return !0
        },__ondragend: function() {
            this.isDragend = !0
        },ondragend: function(e, t) {
            this.isDragend && e.target && (!this.timelineOption.realtime && this._setCurrentOption(), t.dragOut = !0, t.dragIn = !0, t.needRefresh = !1, this.isDragend = !1, this._syncHandleShape())
        },last: function() {
            return this.timelineOption.autoPlay && this.stop(), this.currentIndex -= 1, this.currentIndex < 0 && (this.currentIndex = this.timelineOption.data.length - 1), this._onFrame(), this.currentIndex
        },next: function() {
            return this.timelineOption.autoPlay && this.stop(), this.currentIndex += 1, this.currentIndex >= this.timelineOption.data.length && (this.currentIndex = 0), 
            this._onFrame(), this.currentIndex
        },play: function(e, t) {
            return this._ctrPlayShape && "playing" != this._ctrPlayShape.style.status && (this._ctrPlayShape.style.status = "playing", this.zr.modShape(this._ctrPlayShape.id), this.zr.refreshNextFrame()), this.timelineOption.autoPlay = null != t ? t : !0, this.timelineOption.autoPlay || clearTimeout(this.playTicket), this.currentIndex = null != e ? e : this.currentIndex + 1, this.currentIndex >= this.timelineOption.data.length && (this.currentIndex = 0), this._onFrame(), this.currentIndex
        },stop: function() {
            return this._ctrPlayShape && "stop" != this._ctrPlayShape.style.status && (this._ctrPlayShape.style.status = "stop", this.zr.modShape(this._ctrPlayShape.id), this.zr.refreshNextFrame()), this.timelineOption.autoPlay = !1, clearTimeout(this.playTicket), this.currentIndex
        },resize: function() {
            this.timelineOption.show && (this.clear(), this._buildShape(), this._syncHandleShape())
        },setTheme: function(e) {
            this.timelineOption = this.reformOption(l.clone(this.option.timeline)), this.timelineOption.label.textStyle = this.getTextStyle(this.timelineOption.label.textStyle), this.timelineOption.checkpointStyle.label.textStyle = this.getTextStyle(this.timelineOption.checkpointStyle.label.textStyle), this.myChart.canvasSupported || (this.timelineOption.realtime = !1), this.timelineOption.show && e && (this.clear(), this._buildShape(), this._syncHandleShape())
        },onbeforDispose: function() {
            clearTimeout(this.playTicket)
        }}, o.prototype.iconLibrary.timelineControl = i, l.inherits(t, n), e("../component").define("timeline", t), t
}), define("zrender/shape/Image", ["require", "./Base", "../tool/util"], function(e) {
    var t = e("./Base"), i = function(e) {
        t.call(this, e)
    };
    return i.prototype = {type: "image",brush: function(e, t, i) {
            var n = this.style || {};
            t && (n = this.getHighlightStyle(n, this.highlightStyle || {}));
            var a = n.image, o = this;
            if (this._imageCache || (this._imageCache = {}), "string" == typeof a) {
                var r = a;
                this._imageCache[r] ? a = this._imageCache[r] : (a = new Image, a.onload = function() {
                    a.onload = null, o.modSelf(), i()
                }, a.src = r, this._imageCache[r] = a)
            }
            if (a) {
                if ("IMG" == a.nodeName.toUpperCase())
                    if (window.ActiveXObject) {
                        if ("complete" != a.readyState)
                            return
                    } else if (!a.complete)
                        return;
                var s = n.width || a.width, l = n.height || a.height, h = n.x, d = n.y;
                if (!a.width || !a.height)
                    return;
                if (e.save(), this.doClip(e), this.setContext(e, n), this.setTransform(e), n.sWidth && n.sHeight) {
                    var c = n.sx || 0, m = n.sy || 0;
                    e.drawImage(a, c, m, n.sWidth, n.sHeight, h, d, s, l)
                } else if (n.sx && n.sy) {
                    var c = n.sx, m = n.sy, p = s - c, u = l - m;
                    e.drawImage(a, c, m, p, u, h, d, s, l)
                } else
                    e.drawImage(a, h, d, s, l);
                n.width || (n.width = s), n.height || (n.height = l), this.style.width || (this.style.width = s), this.style.height || (this.style.height = l), this.drawText(e, n, this.style), e.restore()
            }
        },getRect: function(e) {
            return {x: e.x,y: e.y,width: e.width,height: e.height}
        },clearCache: function() {
            this._imageCache = {}
        }}, e("../tool/util").inherits(i, t), i
}), define("zrender/loadingEffect/Bar", ["require", "./Base", "../tool/util", "../tool/color", "../shape/Rectangle"], function(e) {
    function t(e) {
        i.call(this, e)
    }
    var i = e("./Base"), n = e("../tool/util"), a = e("../tool/color"), o = e("../shape/Rectangle");
    return n.inherits(t, i), t.prototype._start = function(e, t) {
        var i = n.merge(this.options, {textStyle: {color: "#888"},backgroundColor: "rgba(250, 250, 250, 0.8)",effectOption: {x: 0,y: this.canvasHeight / 2 - 30,width: this.canvasWidth,height: 5,brushType: "fill",timeInterval: 100}}), r = this.createTextShape(i.textStyle), s = this.createBackgroundShape(i.backgroundColor), l = i.effectOption, h = new o({highlightStyle: n.clone(l)});
        return h.highlightStyle.color = l.color || a.getLinearGradient(l.x, l.y, l.x + l.width, l.y + l.height, [[0, "#ff6400"], [.5, "#ffe100"], [1, "#b1ff00"]]), null != i.progress ? (e(s), h.highlightStyle.width = this.adjust(i.progress, [0, 1]) * i.effectOption.width, e(h), e(r), void t()) : (h.highlightStyle.width = 0, setInterval(function() {
            e(s), h.highlightStyle.width < l.width ? h.highlightStyle.width += 8 : h.highlightStyle.width = 0, e(h), e(r), t()
        }, l.timeInterval))
    }, t
}), define("zrender/loadingEffect/Bubble", ["require", "./Base", "../tool/util", "../tool/color", "../shape/Circle"], function(e) {
    function t(e) {
        i.call(this, e)
    }
    var i = e("./Base"), n = e("../tool/util"), a = e("../tool/color"), o = e("../shape/Circle");
    return n.inherits(t, i), t.prototype._start = function(e, t) {
        for (var i = n.merge(this.options, {textStyle: {color: "#888"},backgroundColor: "rgba(250, 250, 250, 0.8)",effect: {n: 50,lineWidth: 2,brushType: "stroke",color: "random",timeInterval: 100}}), r = this.createTextShape(i.textStyle), s = this.createBackgroundShape(i.backgroundColor), l = i.effect, h = l.n, d = l.brushType, c = l.lineWidth, m = [], p = this.canvasWidth, u = this.canvasHeight, V = 0; h > V; V++) {
            var U = "random" == l.color ? a.alpha(a.random(), .3) : l.color;
            m[V] = new o({highlightStyle: {x: Math.ceil(Math.random() * p),y: Math.ceil(Math.random() * u),r: Math.ceil(40 * Math.random()),brushType: d,color: U,strokeColor: U,lineWidth: c},animationY: Math.ceil(20 * Math.random())})
        }
        return setInterval(function() {
            e(s);
            for (var i = 0; h > i; i++) {
                var n = m[i].highlightStyle;
                n.y - m[i].animationY + n.r <= 0 && (m[i].highlightStyle.y = u + n.r, m[i].highlightStyle.x = Math.ceil(Math.random() * p)), m[i].highlightStyle.y -= m[i].animationY, e(m[i])
            }
            e(r), t()
        }, l.timeInterval)
    }, t
}), define("zrender/loadingEffect/DynamicLine", ["require", "./Base", "../tool/util", "../tool/color", "../shape/Line"], function(e) {
    function t(e) {
        i.call(this, e)
    }
    var i = e("./Base"), n = e("../tool/util"), a = e("../tool/color"), o = e("../shape/Line");
    return n.inherits(t, i), t.prototype._start = function(e, t) {
        for (var i = n.merge(this.options, {textStyle: {color: "#fff"},backgroundColor: "rgba(0, 0, 0, 0.8)",effectOption: {n: 30,lineWidth: 1,color: "random",timeInterval: 100}}), r = this.createTextShape(i.textStyle), s = this.createBackgroundShape(i.backgroundColor), l = i.effectOption, h = l.n, d = l.lineWidth, c = [], m = this.canvasWidth, p = this.canvasHeight, u = 0; h > u; u++) {
            var V = -Math.ceil(1e3 * Math.random()), U = Math.ceil(400 * Math.random()), g = Math.ceil(Math.random() * p), f = "random" == l.color ? a.random() : l.color;
            c[u] = new o({highlightStyle: {xStart: V,yStart: g,xEnd: V + U,yEnd: g,strokeColor: f,lineWidth: d},animationX: Math.ceil(100 * Math.random()),len: U})
        }
        return setInterval(function() {
            e(s);
            for (var i = 0; h > i; i++) {
                var n = c[i].highlightStyle;
                n.xStart >= m && (c[i].len = Math.ceil(400 * Math.random()), n.xStart = -400, n.xEnd = -400 + c[i].len, n.yStart = Math.ceil(Math.random() * p), n.yEnd = n.yStart), n.xStart += c[i].animationX, n.xEnd += c[i].animationX, e(c[i])
            }
            e(r), t()
        }, l.timeInterval)
    }, t
}), define("zrender/loadingEffect/Ring", ["require", "./Base", "../tool/util", "../tool/color", "../shape/Ring", "../shape/Sector"], function(e) {
    function t(e) {
        i.call(this, e)
    }
    var i = e("./Base"), n = e("../tool/util"), a = e("../tool/color"), o = e("../shape/Ring"), r = e("../shape/Sector");
    return n.inherits(t, i), t.prototype._start = function(e, t) {
        var i = n.merge(this.options, {textStyle: {color: "#07a"},backgroundColor: "rgba(250, 250, 250, 0.8)",effect: {x: this.canvasWidth / 2,y: this.canvasHeight / 2,r0: 60,r: 100,color: "#bbdcff",brushType: "fill",textPosition: "inside",textFont: "normal 30px verdana",textColor: "rgba(30, 144, 255, 0.6)",timeInterval: 100}}), s = i.effect, l = i.textStyle;
        null == l.x && (l.x = s.x), null == l.y && (l.y = s.y + (s.r0 + s.r) / 2 - 5);
        for (var h = this.createTextShape(i.textStyle), d = this.createBackgroundShape(i.backgroundColor), c = s.x, m = s.y, p = s.r0 + 6, u = s.r - 6, V = s.color, U = a.lift(V, .1), g = new o({highlightStyle: n.clone(s)}), f = [], y = a.getGradientColors(["#ff6400", "#ffe100", "#97ff00"], 25), b = 15, _ = 240, x = 0; 16 > x; x++)
            f.push(new r({highlightStyle: {x: c,y: m,r0: p,r: u,startAngle: _ - b,endAngle: _,brushType: "fill",color: U},_color: a.getLinearGradient(c + p * Math.cos(_, !0), m - p * Math.sin(_, !0), c + p * Math.cos(_ - b, !0), m - p * Math.sin(_ - b, !0), [[0, y[2 * x]], [1, y[2 * x + 1]]])})), _ -= b;
        _ = 360;
        for (var x = 0; 4 > x; x++)
            f.push(new r({highlightStyle: {x: c,y: m,r0: p,r: u,startAngle: _ - b,endAngle: _,brushType: "fill",color: U},_color: a.getLinearGradient(c + p * Math.cos(_, !0), m - p * Math.sin(_, !0), c + p * Math.cos(_ - b, !0), m - p * Math.sin(_ - b, !0), [[0, y[2 * x + 32]], [1, y[2 * x + 33]]])})), _ -= b;
        var k = 0;
        if (null != i.progress) {
            e(d), k = 100 * this.adjust(i.progress, [0, 1]).toFixed(2) / 5, g.highlightStyle.text = 5 * k + "%", e(g);
            for (var x = 0; 20 > x; x++)
                f[x].highlightStyle.color = k > x ? f[x]._color : U, e(f[x]);
            return e(h), void t()
        }
        return setInterval(function() {
            e(d), k += k >= 20 ? -20 : 1, e(g);
            for (var i = 0; 20 > i; i++)
                f[i].highlightStyle.color = k > i ? f[i]._color : U, e(f[i]);
            e(h), t()
        }, s.timeInterval)
    }, t
}), define("zrender/loadingEffect/Spin", ["require", "./Base", "../tool/util", "../tool/color", "../tool/area", "../shape/Sector"], function(e) {
    function t(e) {
        i.call(this, e)
    }
    var i = e("./Base"), n = e("../tool/util"), a = e("../tool/color"), o = e("../tool/area"), r = e("../shape/Sector");
    return n.inherits(t, i), t.prototype._start = function(e, t) {
        var i = n.merge(this.options, {textStyle: {color: "#fff",textAlign: "start"},backgroundColor: "rgba(0, 0, 0, 0.8)"}), s = this.createTextShape(i.textStyle), l = 10, h = o.getTextWidth(s.highlightStyle.text, s.highlightStyle.textFont), d = o.getTextHeight(s.highlightStyle.text, s.highlightStyle.textFont), c = n.merge(this.options.effect || {}, {r0: 9,r: 15,n: 18,color: "#fff",timeInterval: 100}), m = this.getLocation(this.options.textStyle, h + l + 2 * c.r, Math.max(2 * c.r, d));
        c.x = m.x + c.r, c.y = s.highlightStyle.y = m.y + m.height / 2, s.highlightStyle.x = c.x + c.r + l;
        for (var p = this.createBackgroundShape(i.backgroundColor), u = c.n, V = c.x, U = c.y, g = c.r0, f = c.r, y = c.color, b = [], _ = Math.round(180 / u), x = 0; u > x; x++)
            b[x] = new r({highlightStyle: {x: V,y: U,r0: g,r: f,startAngle: _ * x * 2,endAngle: _ * x * 2 + _,color: a.alpha(y, (x + 1) / u),brushType: "fill"}});
        var k = [0, V, U];
        return setInterval(function() {
            e(p), k[0] -= .3;
            for (var i = 0; u > i; i++)
                b[i].rotation = k, e(b[i]);
            e(s), t()
        }, c.timeInterval)
    }, t
}), define("zrender/loadingEffect/Whirling", ["require", "./Base", "../tool/util", "../tool/area", "../shape/Ring", "../shape/Droplet", "../shape/Circle"], function(e) {
    function t(e) {
        i.call(this, e)
    }
    var i = e("./Base"), n = e("../tool/util"), a = e("../tool/area"), o = e("../shape/Ring"), r = e("../shape/Droplet"), s = e("../shape/Circle");
    return n.inherits(t, i), t.prototype._start = function(e, t) {
        var i = n.merge(this.options, {textStyle: {color: "#888",textAlign: "start"},backgroundColor: "rgba(250, 250, 250, 0.8)"}), l = this.createTextShape(i.textStyle), h = 10, d = a.getTextWidth(l.highlightStyle.text, l.highlightStyle.textFont), c = a.getTextHeight(l.highlightStyle.text, l.highlightStyle.textFont), m = n.merge(this.options.effect || {}, {r: 18,colorIn: "#fff",colorOut: "#555",colorWhirl: "#6cf",timeInterval: 50}), p = this.getLocation(this.options.textStyle, d + h + 2 * m.r, Math.max(2 * m.r, c));
        m.x = p.x + m.r, m.y = l.highlightStyle.y = p.y + p.height / 2, l.highlightStyle.x = m.x + m.r + h;
        var u = this.createBackgroundShape(i.backgroundColor), V = new r({highlightStyle: {a: Math.round(m.r / 2),b: Math.round(m.r - m.r / 6),brushType: "fill",color: m.colorWhirl}}), U = new s({highlightStyle: {r: Math.round(m.r / 6),brushType: "fill",color: m.colorIn}}), g = new o({highlightStyle: {r0: Math.round(m.r - m.r / 3),r: m.r,brushType: "fill",color: m.colorOut}}), f = [0, m.x, m.y];
        return V.highlightStyle.x = U.highlightStyle.x = g.highlightStyle.x = f[1], V.highlightStyle.y = U.highlightStyle.y = g.highlightStyle.y = f[2], setInterval(function() {
            e(u), e(g), f[0] -= .3, V.rotation = f, e(V), e(U), e(l), t()
        }, m.timeInterval)
    }, t
}), define("echarts/theme/macarons", [], function() {
    var e = {color: ["#2ec7c9", "#b6a2de", "#5ab1ef", "#ffb980", "#d87a80", "#8d98b3", "#e5cf0d", "#97b552", "#95706d", "#dc69aa", "#07a2a4", "#9a7fd1", "#588dd5", "#f5994e", "#c05050", "#59678c", "#c9ab00", "#7eb00a", "#6f5553", "#c14089"],title: {textStyle: {fontWeight: "normal",color: "#008acd"}},dataRange: {itemWidth: 15,color: ["#5ab1ef", "#e0ffff"]},toolbox: {color: ["#1e90ff", "#1e90ff", "#1e90ff", "#1e90ff"],effectiveColor: "#ff4500"},tooltip: {backgroundColor: "rgba(50,50,50,0.5)",axisPointer: {type: "line",lineStyle: {color: "#008acd"},crossStyle: {color: "#008acd"},shadowStyle: {color: "rgba(200,200,200,0.2)"}}},dataZoom: {dataBackgroundColor: "#efefff",fillerColor: "rgba(182,162,222,0.2)",handleColor: "#008acd"},grid: {borderColor: "#eee"},categoryAxis: {axisLine: {lineStyle: {color: "#008acd"}},splitLine: {lineStyle: {color: ["#eee"]}}},valueAxis: {axisLine: {lineStyle: {color: "#008acd"}},splitArea: {show: !0,areaStyle: {color: ["rgba(250,250,250,0.1)", "rgba(200,200,200,0.1)"]}},splitLine: {lineStyle: {color: ["#eee"]}}},polar: {axisLine: {lineStyle: {color: "#ddd"}},splitArea: {show: !0,areaStyle: {color: ["rgba(250,250,250,0.2)", "rgba(200,200,200,0.2)"]}},splitLine: {lineStyle: {color: "#ddd"}}},timeline: {lineStyle: {color: "#008acd"},controlStyle: {normal: {color: "#008acd"},emphasis: {color: "#008acd"}},symbol: "emptyCircle",symbolSize: 3},bar: {itemStyle: {normal: {barBorderRadius: 5},emphasis: {barBorderRadius: 5}}},line: {smooth: !0,symbol: "emptyCircle",symbolSize: 3},k: {itemStyle: {normal: {color: "#d87a80",color0: "#2ec7c9",lineStyle: {color: "#d87a80",color0: "#2ec7c9"}}}},scatter: {symbol: "circle",symbolSize: 4},radar: {symbol: "emptyCircle",symbolSize: 3},map: {itemStyle: {normal: {areaStyle: {color: "#ddd"},label: {textStyle: {color: "#d87a80"}}},emphasis: {areaStyle: {color: "#fe994e"}}}},force: {itemStyle: {normal: {linkStyle: {color: "#1e90ff"}}}},chord: {itemStyle: {normal: {borderWidth: 1,borderColor: "rgba(128, 128, 128, 0.5)",chordStyle: {lineStyle: {color: "rgba(128, 128, 128, 0.5)"}}},emphasis: {borderWidth: 1,borderColor: "rgba(128, 128, 128, 0.5)",chordStyle: {lineStyle: {color: "rgba(128, 128, 128, 0.5)"}}}}},gauge: {axisLine: {lineStyle: {color: [[.2, "#2ec7c9"], [.8, "#5ab1ef"], [1, "#d87a80"]],width: 10}},axisTick: {splitNumber: 10,length: 15,lineStyle: {color: "auto"}},splitLine: {length: 22,lineStyle: {color: "auto"}},pointer: {width: 5}},textStyle: {fontFamily: "微软雅黑, Arial, Verdana, sans-serif"}};
    return e
}), define("echarts/theme/infographic", [], function() {
    var e = {color: ["#C1232B", "#B5C334", "#FCCE10", "#E87C25", "#27727B", "#FE8463", "#9BCA63", "#FAD860", "#F3A43B", "#60C0DD", "#D7504B", "#C6E579", "#F4E001", "#F0805A", "#26C0C0"],title: {textStyle: {fontWeight: "normal",color: "#27727B"}},dataRange: {x: "right",y: "center",itemWidth: 5,itemHeight: 25,color: ["#C1232B", "#FCCE10"]},toolbox: {color: ["#C1232B", "#B5C334", "#FCCE10", "#E87C25", "#27727B", "#FE8463", "#9BCA63", "#FAD860", "#F3A43B", "#60C0DD"],effectiveColor: "#ff4500"},tooltip: {backgroundColor: "rgba(50,50,50,0.5)",axisPointer: {type: "line",lineStyle: {color: "#27727B",type: "dashed"},crossStyle: {color: "#27727B"},shadowStyle: {color: "rgba(200,200,200,0.3)"}}},dataZoom: {dataBackgroundColor: "rgba(181,195,52,0.3)",fillerColor: "rgba(181,195,52,0.2)",handleColor: "#27727B"},grid: {borderWidth: 0},categoryAxis: {axisLine: {lineStyle: {color: "#27727B"}},splitLine: {show: !1}},valueAxis: {axisLine: {show: !1},splitArea: {show: !1},splitLine: {lineStyle: {color: ["#ccc"],type: "dashed"}}},polar: {axisLine: {lineStyle: {color: "#ddd"}},splitArea: {show: !0,areaStyle: {color: ["rgba(250,250,250,0.2)", "rgba(200,200,200,0.2)"]}},splitLine: {lineStyle: {color: "#ddd"}}},timeline: {lineStyle: {color: "#27727B"},controlStyle: {normal: {color: "#27727B"},emphasis: {color: "#27727B"}},symbol: "emptyCircle",symbolSize: 3},line: {itemStyle: {normal: {borderWidth: 2,borderColor: "#fff",lineStyle: {width: 3}},emphasis: {borderWidth: 0}},symbol: "circle",symbolSize: 3.5},k: {itemStyle: {normal: {color: "#C1232B",color0: "#B5C334",lineStyle: {width: 1,color: "#C1232B",color0: "#B5C334"}}}},scatter: {itemStyle: {normal: {borderWidth: 1,borderColor: "rgba(200,200,200,0.5)"},emphasis: {borderWidth: 0}},symbol: "star4",symbolSize: 4},radar: {symbol: "emptyCircle",symbolSize: 3},map: {itemStyle: {normal: {areaStyle: {color: "#ddd"},label: {textStyle: {color: "#C1232B"}}},emphasis: {areaStyle: {color: "#fe994e"},label: {textStyle: {color: "rgb(100,0,0)"}}}}},force: {itemStyle: {normal: {linkStyle: {color: "#27727B"}}}},chord: {itemStyle: {normal: {borderWidth: 1,borderColor: "rgba(128, 128, 128, 0.5)",chordStyle: {lineStyle: {color: "rgba(128, 128, 128, 0.5)"}}},emphasis: {borderWidth: 1,borderColor: "rgba(128, 128, 128, 0.5)",chordStyle: {lineStyle: {color: "rgba(128, 128, 128, 0.5)"}}}}},gauge: {center: ["50%", "80%"],radius: "100%",startAngle: 180,endAngle: 0,axisLine: {show: !0,lineStyle: {color: [[.2, "#B5C334"], [.8, "#27727B"], [1, "#C1232B"]],width: "40%"}},axisTick: {splitNumber: 2,length: 5,lineStyle: {color: "#fff"}},axisLabel: {textStyle: {color: "#fff",fontWeight: "bolder"}},splitLine: {length: "5%",lineStyle: {color: "#fff"}},pointer: {width: "40%",length: "80%",color: "#fff"},title: {offsetCenter: [0, -20],textStyle: {color: "auto",fontSize: 20}},detail: {offsetCenter: [0, 0],textStyle: {color: "auto",fontSize: 40}}},textStyle: {fontFamily: "微软雅黑, Arial, Verdana, sans-serif"}};
    return e
}), define("zrender/dep/excanvas", ["require"], function() {
    return document.createElement("canvas").getContext ? G_vmlCanvasManager = !1 : !function() {
        function e() {
            return this.context_ || (this.context_ = new b(this))
        }
        function t(e, t) {
            var i = O.call(arguments, 2);
            return function() {
                return e.apply(t, i.concat(O.call(arguments)))
            }
        }
        function i(e) {
            return String(e).replace(/&/g, "&amp;").replace(/"/g, "&quot;")
        }
        function n(e, t, i) {
            e.namespaces[t] || e.namespaces.add(t, i, "#default#VML")
        }
        function a(e) {
            if (n(e, "g_vml_", "urn:schemas-microsoft-com:vml"), n(e, "g_o_", "urn:schemas-microsoft-com:office:office"), !e.styleSheets.ex_canvas_) {
                var t = e.createStyleSheet();
                t.owningElement.id = "ex_canvas_", t.cssText = "canvas{display:inline-block;overflow:hidden;text-align:left;width:300px;height:150px}"
            }
        }
        function o(e) {
            var t = e.srcElement;
            switch (e.propertyName) {
                case "width":
                    t.getContext().clearRect(), t.style.width = t.attributes.width.nodeValue + "px", t.firstChild.style.width = t.clientWidth + "px";
                    break;
                case "height":
                    t.getContext().clearRect(), t.style.height = t.attributes.height.nodeValue + "px", t.firstChild.style.height = t.clientHeight + "px"
            }
        }
        function r(e) {
            var t = e.srcElement;
            t.firstChild && (t.firstChild.style.width = t.clientWidth + "px", t.firstChild.style.height = t.clientHeight + "px")
        }
        function s() {
            return [[1, 0, 0], [0, 1, 0], [0, 0, 1]]
        }
        function l(e, t) {
            for (var i = s(), n = 0; 3 > n; n++)
                for (var a = 0; 3 > a; a++) {
                    for (var o = 0, r = 0; 3 > r; r++)
                        o += e[n][r] * t[r][a];
                    i[n][a] = o
                }
            return i
        }
        function h(e, t) {
            t.fillStyle = e.fillStyle, t.lineCap = e.lineCap, t.lineJoin = e.lineJoin, t.lineWidth = e.lineWidth, t.miterLimit = e.miterLimit, t.shadowBlur = e.shadowBlur, t.shadowColor = e.shadowColor, t.shadowOffsetX = e.shadowOffsetX, t.shadowOffsetY = e.shadowOffsetY, t.strokeStyle = e.strokeStyle, t.globalAlpha = e.globalAlpha, t.font = e.font, t.textAlign = e.textAlign, t.textBaseline = e.textBaseline, t.scaleX_ = e.scaleX_, t.scaleY_ = e.scaleY_, t.lineScale_ = e.lineScale_
        }
        function d(e) {
            var t = e.indexOf("(", 3), i = e.indexOf(")", t + 1), n = e.substring(t + 1, i).split(",");
            return (4 != n.length || "a" != e.charAt(3)) && (n[3] = 1), n
        }
        function c(e) {
            return parseFloat(e) / 100
        }
        function m(e, t, i) {
            return Math.min(i, Math.max(t, e))
        }
        function p(e) {
            var t, i, n, a, o, r;
            if (a = parseFloat(e[0]) / 360 % 360, 0 > a && a++, o = m(c(e[1]), 0, 1), r = m(c(e[2]), 0, 1), 0 == o)
                t = i = n = r;
            else {
                var s = .5 > r ? r * (1 + o) : r + o - r * o, l = 2 * r - s;
                t = u(l, s, a + 1 / 3), i = u(l, s, a), n = u(l, s, a - 1 / 3)
            }
            return "#" + D[Math.floor(255 * t)] + D[Math.floor(255 * i)] + D[Math.floor(255 * n)]
        }
        function u(e, t, i) {
            return 0 > i && i++, i > 1 && i--, 1 > 6 * i ? e + 6 * (t - e) * i : 1 > 2 * i ? t : 2 > 3 * i ? e + (t - e) * (2 / 3 - i) * 6 : e
        }
        function V(e) {
            if (e in R)
                return R[e];
            var t, i = 1;
            if (e = String(e), "#" == e.charAt(0))
                t = e;
            else if (/^rgb/.test(e)) {
                for (var n, a = d(e), t = "#", o = 0; 3 > o; o++)
                    n = -1 != a[o].indexOf("%") ? Math.floor(255 * c(a[o])) : +a[o], t += D[m(n, 0, 255)];
                i = +a[3]
            } else if (/^hsl/.test(e)) {
                var a = d(e);
                t = p(a), i = a[3]
            } else
                t = H[e] || e;
            return R[e] = {color: t,alpha: i}
        }
        function U(e) {
            if (Y[e])
                return Y[e];
            var t, i = document.createElement("div"), n = i.style;
            try {
                n.font = e, t = n.fontFamily.split(",")[0]
            } catch (a) {
            }
            return Y[e] = {style: n.fontStyle || G.style,variant: n.fontVariant || G.variant,weight: n.fontWeight || G.weight,size: n.fontSize || G.size,family: t || G.family}
        }
        function g(e, t) {
            var i = {};
            for (var n in e)
                i[n] = e[n];
            var a = parseFloat(t.currentStyle.fontSize), o = parseFloat(e.size);
            return i.size = "number" == typeof e.size ? e.size : -1 != e.size.indexOf("px") ? o : -1 != e.size.indexOf("em") ? a * o : -1 != e.size.indexOf("%") ? a / 100 * o : -1 != e.size.indexOf("pt") ? o / .75 : a, i
        }
        function f(e) {
            return e.style + " " + e.variant + " " + e.weight + " " + e.size + "px '" + e.family + "'"
        }
        function y(e) {
            return Z[e] || "square"
        }
        function b(e) {
            this.m_ = s(), this.mStack_ = [], this.aStack_ = [], this.currentPath_ = [], this.strokeStyle = "#000", this.fillStyle = "#000", this.lineWidth = 1, this.lineJoin = "miter", this.lineCap = "butt", this.miterLimit = 1 * F, this.globalAlpha = 1, this.font = "12px 微软雅黑", this.textAlign = "left", this.textBaseline = "alphabetic", this.canvas = e;
            var t = "width:" + e.clientWidth + "px;height:" + e.clientHeight + "px;overflow:hidden;position:absolute", i = e.ownerDocument.createElement("div");
            i.style.cssText = t, e.appendChild(i);
            var n = i.cloneNode(!1);
            n.style.backgroundColor = "#fff", n.style.filter = "alpha(opacity=0)", e.appendChild(n), this.element_ = i, this.scaleX_ = 1, this.scaleY_ = 1, this.lineScale_ = 1
        }
        function _(e, t, i, n) {
            e.currentPath_.push({type: "bezierCurveTo",cp1x: t.x,cp1y: t.y,cp2x: i.x,cp2y: i.y,x: n.x,y: n.y}), e.currentX_ = n.x, e.currentY_ = n.y
        }
        function x(e, t) {
            var i = V(e.strokeStyle), n = i.color, a = i.alpha * e.globalAlpha, o = e.lineScale_ * e.lineWidth;
            1 > o && (a *= o), t.push("<g_vml_:stroke", ' opacity="', a, '"', ' joinstyle="', e.lineJoin, '"', ' miterlimit="', e.miterLimit, '"', ' endcap="', y(e.lineCap), '"', ' weight="', o, 'px"', ' color="', n, '" />')
        }
        function k(e, t, i, n) {
            var a = e.fillStyle, o = e.scaleX_, r = e.scaleY_, s = n.x - i.x, l = n.y - i.y;
            if (a instanceof W) {
                var h = 0, d = {x: 0,y: 0}, c = 0, m = 1;
                if ("gradient" == a.type_) {
                    var p = a.x0_ / o, u = a.y0_ / r, U = a.x1_ / o, g = a.y1_ / r, f = v(e, p, u), y = v(e, U, g), b = y.x - f.x, _ = y.y - f.y;
                    h = 180 * Math.atan2(b, _) / Math.PI, 0 > h && (h += 360), 1e-6 > h && (h = 0)
                } else {
                    var f = v(e, a.x0_, a.y0_);
                    d = {x: (f.x - i.x) / s,y: (f.y - i.y) / l}, s /= o * F, l /= r * F;
                    var x = C.max(s, l);
                    c = 2 * a.r0_ / x, m = 2 * a.r1_ / x - c
                }
                var k = a.colors_;
                k.sort(function(e, t) {
                    return e.offset - t.offset
                });
                for (var L = k.length, w = k[0].color, I = k[L - 1].color, S = k[0].alpha * e.globalAlpha, K = k[L - 1].alpha * e.globalAlpha, T = [], E = 0; L > E; E++) {
                    var z = k[E];
                    T.push(z.offset * m + c + " " + z.color)
                }
                t.push('<g_vml_:fill type="', a.type_, '"', ' method="none" focus="100%"', ' color="', w, '"', ' color2="', I, '"', ' colors="', T.join(","), '"', ' opacity="', K, '"', ' g_o_:opacity2="', S, '"', ' angle="', h, '"', ' focusposition="', d.x, ",", d.y, '" />')
            } else if (a instanceof X) {
                if (s && l) {
                    var A = -i.x, M = -i.y;
                    t.push("<g_vml_:fill", ' position="', A / s * o * o, ",", M / l * r * r, '"', ' type="tile"', ' src="', a.src_, '" />')
                }
            } else {
                var J = V(e.fillStyle), O = J.color, P = J.alpha * e.globalAlpha;
                t.push('<g_vml_:fill color="', O, '" opacity="', P, '" />')
            }
        }
        function v(e, t, i) {
            var n = e.m_;
            return {x: F * (t * n[0][0] + i * n[1][0] + n[2][0]) - J,y: F * (t * n[0][1] + i * n[1][1] + n[2][1]) - J}
        }
        function L(e) {
            return isFinite(e[0][0]) && isFinite(e[0][1]) && isFinite(e[1][0]) && isFinite(e[1][1]) && isFinite(e[2][0]) && isFinite(e[2][1])
        }
        function w(e, t, i) {
            if (L(t) && (e.m_ = t, e.scaleX_ = Math.sqrt(t[0][0] * t[0][0] + t[0][1] * t[0][1]), e.scaleY_ = Math.sqrt(t[1][0] * t[1][0] + t[1][1] * t[1][1]), i)) {
                var n = t[0][0] * t[1][1] - t[0][1] * t[1][0];
                e.lineScale_ = M(A(n))
            }
        }
        function W(e) {
            this.type_ = e, this.x0_ = 0, this.y0_ = 0, this.r0_ = 0, this.x1_ = 0, this.y1_ = 0, this.r1_ = 0, this.colors_ = []
        }
        function X(e, t) {
            switch (S(e), t) {
                case "repeat":
                case null:
                case "":
                    this.repetition_ = "repeat";
                    break;
                case "repeat-x":
                case "repeat-y":
                case "no-repeat":
                    this.repetition_ = t;
                    break;
                default:
                    I("SYNTAX_ERR")
            }
            this.src_ = e.src, this.width_ = e.width, this.height_ = e.height
        }
        function I(e) {
            throw new K(e)
        }
        function S(e) {
            e && 1 == e.nodeType && "IMG" == e.tagName || I("TYPE_MISMATCH_ERR"), "complete" != e.readyState && I("INVALID_STATE_ERR")
        }
        function K(e) {
            this.code = this[e], this.message = e + ": DOM Exception " + this.code
        }
        var C = Math, T = C.round, E = C.sin, z = C.cos, A = C.abs, M = C.sqrt, F = 10, J = F / 2, O = (+navigator.userAgent.match(/MSIE ([\d.]+)?/)[1], Array.prototype.slice);
        a(document);
        var P = {init: function(e) {
                var i = e || document;
                i.createElement("canvas"), i.attachEvent("onreadystatechange", t(this.init_, this, i))
            },init_: function(e) {
                for (var t = e.getElementsByTagName("canvas"), i = 0; i < t.length; i++)
                    this.initElement(t[i])
            },initElement: function(t) {
                if (!t.getContext) {
                    t.getContext = e, a(t.ownerDocument), t.innerHTML = "", t.attachEvent("onpropertychange", o), t.attachEvent("onresize", r);
                    var i = t.attributes;
                    i.width && i.width.specified ? t.style.width = i.width.nodeValue + "px" : t.width = t.clientWidth, i.height && i.height.specified ? t.style.height = i.height.nodeValue + "px" : t.height = t.clientHeight
                }
                return t
            }};
        P.init();
        for (var D = [], N = 0; 16 > N; N++)
            for (var B = 0; 16 > B; B++)
                D[16 * N + B] = N.toString(16) + B.toString(16);
        var H = {aliceblue: "#F0F8FF",antiquewhite: "#FAEBD7",aquamarine: "#7FFFD4",azure: "#F0FFFF",beige: "#F5F5DC",bisque: "#FFE4C4",black: "#000000",blanchedalmond: "#FFEBCD",blueviolet: "#8A2BE2",brown: "#A52A2A",burlywood: "#DEB887",cadetblue: "#5F9EA0",chartreuse: "#7FFF00",chocolate: "#D2691E",coral: "#FF7F50",cornflowerblue: "#6495ED",cornsilk: "#FFF8DC",crimson: "#DC143C",cyan: "#00FFFF",darkblue: "#00008B",darkcyan: "#008B8B",darkgoldenrod: "#B8860B",darkgray: "#A9A9A9",darkgreen: "#006400",darkgrey: "#A9A9A9",darkkhaki: "#BDB76B",darkmagenta: "#8B008B",darkolivegreen: "#556B2F",darkorange: "#FF8C00",darkorchid: "#9932CC",darkred: "#8B0000",darksalmon: "#E9967A",darkseagreen: "#8FBC8F",darkslateblue: "#483D8B",darkslategray: "#2F4F4F",darkslategrey: "#2F4F4F",darkturquoise: "#00CED1",darkviolet: "#9400D3",deeppink: "#FF1493",deepskyblue: "#00BFFF",dimgray: "#696969",dimgrey: "#696969",dodgerblue: "#1E90FF",firebrick: "#B22222",floralwhite: "#FFFAF0",forestgreen: "#228B22",gainsboro: "#DCDCDC",ghostwhite: "#F8F8FF",gold: "#FFD700",goldenrod: "#DAA520",grey: "#808080",greenyellow: "#ADFF2F",honeydew: "#F0FFF0",hotpink: "#FF69B4",indianred: "#CD5C5C",indigo: "#4B0082",ivory: "#FFFFF0",khaki: "#F0E68C",lavender: "#E6E6FA",lavenderblush: "#FFF0F5",lawngreen: "#7CFC00",lemonchiffon: "#FFFACD",lightblue: "#ADD8E6",lightcoral: "#F08080",lightcyan: "#E0FFFF",lightgoldenrodyellow: "#FAFAD2",lightgreen: "#90EE90",lightgrey: "#D3D3D3",lightpink: "#FFB6C1",lightsalmon: "#FFA07A",lightseagreen: "#20B2AA",lightskyblue: "#87CEFA",lightslategray: "#778899",lightslategrey: "#778899",lightsteelblue: "#B0C4DE",lightyellow: "#FFFFE0",limegreen: "#32CD32",linen: "#FAF0E6",magenta: "#FF00FF",mediumaquamarine: "#66CDAA",mediumblue: "#0000CD",mediumorchid: "#BA55D3",mediumpurple: "#9370DB",mediumseagreen: "#3CB371",mediumslateblue: "#7B68EE",mediumspringgreen: "#00FA9A",mediumturquoise: "#48D1CC",mediumvioletred: "#C71585",midnightblue: "#191970",mintcream: "#F5FFFA",mistyrose: "#FFE4E1",moccasin: "#FFE4B5",navajowhite: "#FFDEAD",oldlace: "#FDF5E6",olivedrab: "#6B8E23",orange: "#FFA500",orangered: "#FF4500",orchid: "#DA70D6",palegoldenrod: "#EEE8AA",palegreen: "#98FB98",paleturquoise: "#AFEEEE",palevioletred: "#DB7093",papayawhip: "#FFEFD5",peachpuff: "#FFDAB9",peru: "#CD853F",pink: "#FFC0CB",plum: "#DDA0DD",powderblue: "#B0E0E6",rosybrown: "#BC8F8F",royalblue: "#4169E1",saddlebrown: "#8B4513",salmon: "#FA8072",sandybrown: "#F4A460",seagreen: "#2E8B57",seashell: "#FFF5EE",sienna: "#A0522D",skyblue: "#87CEEB",slateblue: "#6A5ACD",slategray: "#708090",slategrey: "#708090",snow: "#FFFAFA",springgreen: "#00FF7F",steelblue: "#4682B4",tan: "#D2B48C",thistle: "#D8BFD8",tomato: "#FF6347",turquoise: "#40E0D0",violet: "#EE82EE",wheat: "#F5DEB3",whitesmoke: "#F5F5F5",yellowgreen: "#9ACD32"}, R = {}, G = {style: "normal",variant: "normal",weight: "normal",size: 12,family: "微软雅黑"}, Y = {}, Z = {butt: "flat",round: "round"}, Q = b.prototype;
        Q.clearRect = function() {
            this.textMeasureEl_ && (this.textMeasureEl_.removeNode(!0), this.textMeasureEl_ = null), this.element_.innerHTML = ""
        }, Q.beginPath = function() {
            this.currentPath_ = []
        }, Q.moveTo = function(e, t) {
            var i = v(this, e, t);
            this.currentPath_.push({type: "moveTo",x: i.x,y: i.y}), this.currentX_ = i.x, this.currentY_ = i.y
        }, Q.lineTo = function(e, t) {
            var i = v(this, e, t);
            this.currentPath_.push({type: "lineTo",x: i.x,y: i.y}), this.currentX_ = i.x, this.currentY_ = i.y
        }, Q.bezierCurveTo = function(e, t, i, n, a, o) {
            var r = v(this, a, o), s = v(this, e, t), l = v(this, i, n);
            _(this, s, l, r)
        }, Q.quadraticCurveTo = function(e, t, i, n) {
            var a = v(this, e, t), o = v(this, i, n), r = {x: this.currentX_ + 2 / 3 * (a.x - this.currentX_),y: this.currentY_ + 2 / 3 * (a.y - this.currentY_)}, s = {x: r.x + (o.x - this.currentX_) / 3,y: r.y + (o.y - this.currentY_) / 3};
            _(this, r, s, o)
        }, Q.arc = function(e, t, i, n, a, o) {
            i *= F;
            var r = o ? "at" : "wa", s = e + z(n) * i - J, l = t + E(n) * i - J, h = e + z(a) * i - J, d = t + E(a) * i - J;
            s != h || o || (s += .125);
            var c = v(this, e, t), m = v(this, s, l), p = v(this, h, d);
            this.currentPath_.push({type: r,x: c.x,y: c.y,radius: i,xStart: m.x,yStart: m.y,xEnd: p.x,yEnd: p.y})
        }, Q.rect = function(e, t, i, n) {
            this.moveTo(e, t), this.lineTo(e + i, t), this.lineTo(e + i, t + n), this.lineTo(e, t + n), this.closePath()
        }, Q.strokeRect = function(e, t, i, n) {
            var a = this.currentPath_;
            this.beginPath(), this.moveTo(e, t), this.lineTo(e + i, t), this.lineTo(e + i, t + n), this.lineTo(e, t + n), this.closePath(), this.stroke(), this.currentPath_ = a
        }, Q.fillRect = function(e, t, i, n) {
            var a = this.currentPath_;
            this.beginPath(), this.moveTo(e, t), this.lineTo(e + i, t), this.lineTo(e + i, t + n), this.lineTo(e, t + n), this.closePath(), this.fill(), this.currentPath_ = a
        }, Q.createLinearGradient = function(e, t, i, n) {
            var a = new W("gradient");
            return a.x0_ = e, a.y0_ = t, a.x1_ = i, a.y1_ = n, a
        }, Q.createRadialGradient = function(e, t, i, n, a, o) {
            var r = new W("gradientradial");
            return r.x0_ = e, r.y0_ = t, r.r0_ = i, r.x1_ = n, r.y1_ = a, r.r1_ = o, r
        }, Q.drawImage = function(e) {
            var t, i, n, a, o, r, s, l, h = e.runtimeStyle.width, d = e.runtimeStyle.height;
            e.runtimeStyle.width = "auto", e.runtimeStyle.height = "auto";
            var c = e.width, m = e.height;
            if (e.runtimeStyle.width = h, e.runtimeStyle.height = d, 3 == arguments.length)
                t = arguments[1], i = arguments[2], o = r = 0, s = n = c, l = a = m;
            else if (5 == arguments.length)
                t = arguments[1], i = arguments[2], n = arguments[3], a = arguments[4], o = r = 0, s = c, l = m;
            else {
                if (9 != arguments.length)
                    throw Error("Invalid number of arguments");
                o = arguments[1], r = arguments[2], s = arguments[3], l = arguments[4], t = arguments[5], i = arguments[6], n = arguments[7], a = arguments[8]
            }
            var p = v(this, t, i), u = [], V = 10, U = 10, g = y = 1;
            if (u.push(" <g_vml_:group", ' coordsize="', F * V, ",", F * U, '"', ' coordorigin="0,0"', ' style="width:', V, "px;height:", U, "px;position:absolute;"), 1 != this.m_[0][0] || this.m_[0][1] || 1 != this.m_[1][1] || this.m_[1][0]) {
                var f = [], g = this.scaleX_, y = this.scaleY_;
                f.push("M11=", this.m_[0][0] / g, ",", "M12=", this.m_[1][0] / y, ",", "M21=", this.m_[0][1] / g, ",", "M22=", this.m_[1][1] / y, ",", "Dx=", T(p.x / F), ",", "Dy=", T(p.y / F), "");
                var b = p, _ = v(this, t + n, i), x = v(this, t, i + a), k = v(this, t + n, i + a);
                b.x = C.max(b.x, _.x, x.x, k.x), b.y = C.max(b.y, _.y, x.y, k.y), u.push("padding:0 ", T(b.x / F), "px ", T(b.y / F), "px 0;filter:progid:DXImageTransform.Microsoft.Matrix(", f.join(""), ", SizingMethod='clip');")
            } else
                u.push("top:", T(p.y / F), "px;left:", T(p.x / F), "px;");
            u.push(' ">'), (o || r) && u.push('<div style="overflow: hidden; width:', Math.ceil((n + o * n / s) * g), "px;", " height:", Math.ceil((a + r * a / l) * y), "px;", " filter:progid:DxImageTransform.Microsoft.Matrix(Dx=", -o * n / s * g, ",Dy=", -r * a / l * y, ');">'), u.push('<div style="width:', Math.round(g * c * n / s), "px;", " height:", Math.round(y * m * a / l), "px;", " filter:"), this.globalAlpha < 1 && u.push(" progid:DXImageTransform.Microsoft.Alpha(opacity=" + 100 * this.globalAlpha + ")"), u.push(" progid:DXImageTransform.Microsoft.AlphaImageLoader(src=", e.src, ',sizingMethod=scale)">'), (o || r) && u.push("</div>"), u.push("</div></div>"), this.element_.insertAdjacentHTML("BeforeEnd", u.join(""))
        }, Q.stroke = function(e) {
            var t = [], i = 10, n = 10;
            t.push("<g_vml_:shape", ' filled="', !!e, '"', ' style="position:absolute;width:', i, "px;height:", n, 'px;"', ' coordorigin="0,0"', ' coordsize="', F * i, ",", F * n, '"', ' stroked="', !e, '"', ' path="');
            for (var a = {x: null,y: null}, o = {x: null,y: null}, r = 0; r < this.currentPath_.length; r++) {
                var s, l = this.currentPath_[r];
                switch (l.type) {
                    case "moveTo":
                        s = l, t.push(" m ", T(l.x), ",", T(l.y));
                        break;
                    case "lineTo":
                        t.push(" l ", T(l.x), ",", T(l.y));
                        break;
                    case "close":
                        t.push(" x "), l = null;
                        break;
                    case "bezierCurveTo":
                        t.push(" c ", T(l.cp1x), ",", T(l.cp1y), ",", T(l.cp2x), ",", T(l.cp2y), ",", T(l.x), ",", T(l.y));
                        break;
                    case "at":
                    case "wa":
                        t.push(" ", l.type, " ", T(l.x - this.scaleX_ * l.radius), ",", T(l.y - this.scaleY_ * l.radius), " ", T(l.x + this.scaleX_ * l.radius), ",", T(l.y + this.scaleY_ * l.radius), " ", T(l.xStart), ",", T(l.yStart), " ", T(l.xEnd), ",", T(l.yEnd))
                }
                l && ((null == a.x || l.x < a.x) && (a.x = l.x), (null == o.x || l.x > o.x) && (o.x = l.x), (null == a.y || l.y < a.y) && (a.y = l.y), (null == o.y || l.y > o.y) && (o.y = l.y))
            }
            t.push(' ">'), e ? k(this, t, a, o) : x(this, t), t.push("</g_vml_:shape>"), this.element_.insertAdjacentHTML("beforeEnd", t.join(""))
        }, Q.fill = function() {
            this.stroke(!0)
        }, Q.closePath = function() {
            this.currentPath_.push({type: "close"})
        }, Q.save = function() {
            var e = {};
            h(this, e), this.aStack_.push(e), this.mStack_.push(this.m_), this.m_ = l(s(), this.m_)
        }, Q.restore = function() {
            this.aStack_.length && (h(this.aStack_.pop(), this), this.m_ = this.mStack_.pop())
        }, Q.translate = function(e, t) {
            var i = [[1, 0, 0], [0, 1, 0], [e, t, 1]];
            w(this, l(i, this.m_), !1)
        }, Q.rotate = function(e) {
            var t = z(e), i = E(e), n = [[t, i, 0], [-i, t, 0], [0, 0, 1]];
            w(this, l(n, this.m_), !1)
        }, Q.scale = function(e, t) {
            var i = [[e, 0, 0], [0, t, 0], [0, 0, 1]];
            w(this, l(i, this.m_), !0)
        }, Q.transform = function(e, t, i, n, a, o) {
            var r = [[e, t, 0], [i, n, 0], [a, o, 1]];
            w(this, l(r, this.m_), !0)
        }, Q.setTransform = function(e, t, i, n, a, o) {
            var r = [[e, t, 0], [i, n, 0], [a, o, 1]];
            w(this, r, !0)
        }, Q.drawText_ = function(e, t, n, a, o) {
            var r = this.m_, s = 1e3, l = 0, h = s, d = {x: 0,y: 0}, c = [], m = g(U(this.font), this.element_), p = f(m), u = this.element_.currentStyle, V = this.textAlign.toLowerCase();
            
            switch (V) {
                case "left":
                case "center":
                case "right":
                    break;
                case "end":
                    V = "ltr" == u.direction ? "right" : "left";
                    break;
                case "start":
                    V = "rtl" == u.direction ? "right" : "left";
                    break;
                default:
                    V = "left"
            }
            switch (this.textBaseline) {
                case "hanging":
                case "top":
                    d.y = m.size / 1.75;
                    break;
                case "middle":
                    break;
                default:
                case null:
                case "alphabetic":
                case "ideographic":
                case "bottom":
                    d.y = -m.size / 2.25
            }
            switch (V) {
                case "right":
                    l = s, h = .05;
                    break;
                case "center":
                    l = h = s / 2
            }
            var y = v(this, t + d.x, n + d.y);
            c.push('<g_vml_:line from="', -l, ' 0" to="', h, ' 0.05" ', ' coordsize="100 100" coordorigin="0 0"', ' filled="', !o, '" stroked="', !!o, '" style="position:absolute;width:1px;height:1px;">'), o ? x(this, c) : k(this, c, {x: -l,y: 0}, {x: h,y: m.size});
            var b = r[0][0].toFixed(3) + "," + r[1][0].toFixed(3) + "," + r[0][1].toFixed(3) + "," + r[1][1].toFixed(3) + ",0,0", _ = T(y.x / F) + "," + T(y.y / F);
            c.push('<g_vml_:skew on="t" matrix="', b, '" ', ' offset="', _, '" origin="', l, ' 0" />', '<g_vml_:path textpathok="true" />', '<g_vml_:textpath on="true" string="', i(e), '" style="v-text-align:', V, ";font:", i(p), '" /></g_vml_:line>'), this.element_.insertAdjacentHTML("beforeEnd", c.join(""))
        }, Q.fillText = function(e, t, i, n) {
            this.drawText_(e, t, i, n, !1)
        }, Q.strokeText = function(e, t, i, n) {
            this.drawText_(e, t, i, n, !0)
        }, Q.measureText = function(e) {
            if (!this.textMeasureEl_) {
                var t = '<span style="position:absolute;top:-20000px;left:0;padding:0;margin:0;border:none;white-space:pre;"></span>';
                this.element_.insertAdjacentHTML("beforeEnd", t), this.textMeasureEl_ = this.element_.lastChild
            }
            var i = this.element_.ownerDocument;
            this.textMeasureEl_.innerHTML = "";
            try {
                this.textMeasureEl_.style.font = this.font
            } catch (n) {
            }
            return this.textMeasureEl_.appendChild(i.createTextNode(e)), {width: this.textMeasureEl_.offsetWidth}
        }, Q.clip = function() {
        }, Q.arcTo = function() {
        }, Q.createPattern = function(e, t) {
            return new X(e, t)
        }, W.prototype.addColorStop = function(e, t) {
            t = V(t), this.colors_.push({offset: e,color: t.color,alpha: t.alpha})
        };
        var q = K.prototype = new Error;
        q.INDEX_SIZE_ERR = 1, q.DOMSTRING_SIZE_ERR = 2, q.HIERARCHY_REQUEST_ERR = 3, q.WRONG_DOCUMENT_ERR = 4, q.INVALID_CHARACTER_ERR = 5, q.NO_DATA_ALLOWED_ERR = 6, q.NO_MODIFICATION_ALLOWED_ERR = 7, q.NOT_FOUND_ERR = 8, q.NOT_SUPPORTED_ERR = 9, q.INUSE_ATTRIBUTE_ERR = 10, q.INVALID_STATE_ERR = 11, q.SYNTAX_ERR = 12, q.INVALID_MODIFICATION_ERR = 13, q.NAMESPACE_ERR = 14, q.INVALID_ACCESS_ERR = 15, q.VALIDATION_ERR = 16, q.TYPE_MISMATCH_ERR = 17, G_vmlCanvasManager = P, CanvasRenderingContext2D = b, CanvasGradient = W, CanvasPattern = X, DOMException = K
    }(), G_vmlCanvasManager
}), define("zrender/mixin/Eventful", ["require"], function() {
    var e = function() {
        this._handlers = {}
    };
    return e.prototype.one = function(e, t, i) {
        var n = this._handlers;
        return t && e ? (n[e] || (n[e] = []), n[e].push({h: t,one: !0,ctx: i || this}), this) : this
    }, e.prototype.bind = function(e, t, i) {
        var n = this._handlers;
        return t && e ? (n[e] || (n[e] = []), n[e].push({h: t,one: !1,ctx: i || this}), this) : this
    }, e.prototype.unbind = function(e, t) {
        var i = this._handlers;
        if (!e)
            return this._handlers = {}, this;
        if (t) {
            if (i[e]) {
                for (var n = [], a = 0, o = i[e].length; o > a; a++)
                    i[e][a].h != t && n.push(i[e][a]);
                i[e] = n
            }
            i[e] && 0 === i[e].length && delete i[e]
        } else
            delete i[e];
        return this
    }, e.prototype.dispatch = function(e) {
        if (this._handlers[e]) {
            var t = arguments, i = t.length;
            i > 3 && (t = Array.prototype.slice.call(t, 1));
            for (var n = this._handlers[e], a = n.length, o = 0; a > o; ) {
                switch (i) {
                    case 1:
                        n[o].h.call(n[o].ctx);
                        break;
                    case 2:
                        n[o].h.call(n[o].ctx, t[1]);
                        break;
                    case 3:
                        n[o].h.call(n[o].ctx, t[1], t[2]);
                        break;
                    default:
                        n[o].h.apply(n[o].ctx, t)
                }
                n[o].one ? (n.splice(o, 1), a--) : o++
            }
        }
        return this
    }, e.prototype.dispatchWithContext = function(e) {
        if (this._handlers[e]) {
            var t = arguments, i = t.length;
            i > 4 && (t = Array.prototype.slice.call(t, 1, t.length - 1));
            for (var n = t[t.length - 1], a = this._handlers[e], o = a.length, r = 0; o > r; ) {
                switch (i) {
                    case 1:
                        a[r].h.call(n);
                        break;
                    case 2:
                        a[r].h.call(n, t[1]);
                        break;
                    case 3:
                        a[r].h.call(n, t[1], t[2]);
                        break;
                    default:
                        a[r].h.apply(n, t)
                }
                a[r].one ? (a.splice(r, 1), o--) : r++
            }
        }
        return this
    }, e
}), define("zrender/tool/log", ["require", "../config"], function(e) {
    var t = e("../config");
    return function() {
        if (0 !== t.debugMode)
            if (1 == t.debugMode)
                for (var e in arguments)
                    throw new Error(arguments[e]);
            else if (t.debugMode > 1)
                for (var e in arguments)
                    console.log(arguments[e])
    }
}), define("zrender/tool/guid", [], function() {
    var e = 2311;
    return function() {
        return "zrender__" + e++
    }
}), define("zrender/Handler", ["require", "./config", "./tool/env", "./tool/event", "./tool/util", "./tool/vector", "./tool/matrix", "./mixin/Eventful"], function(e) {
    "use strict";
    function t(e, t) {
        return function(i, n) {
            return e.call(t, i, n)
        }
    }
    function i(e, t) {
        return function(i, n, a) {
            return e.call(t, i, n, a)
        }
    }
    function n(e) {
        for (var i = p.length; i--; ) {
            var n = p[i];
            e["_" + n + "Handler"] = t(V[n], e)
        }
    }
    function a(e, t, i) {
        if (this._draggingTarget && this._draggingTarget.id == e.id || e.isSilent())
            return !1;
        var n = this._event;
        if (e.isCover(t, i)) {
            e.hoverable && this.storage.addHover(e);
            for (var a = e.parent; a; ) {
                if (a.clipShape && !a.clipShape.isCover(this._mouseX, this._mouseY))
                    return !1;
                a = a.parent
            }
            return this._lastHover != e && (this._processOutShape(n), this._processDragLeave(n), this._lastHover = e, this._processDragEnter(n)), this._processOverShape(n), this._processDragOver(n), this._hasfound = 1, !0
        }
        return !1
    }
    var o = e("./config"), r = e("./tool/env"), s = e("./tool/event"), l = e("./tool/util"), h = e("./tool/vector"), d = e("./tool/matrix"), c = o.EVENT, m = e("./mixin/Eventful"), p = ["resize", "click", "dblclick", "mousewheel", "mousemove", "mouseout", "mouseup", "mousedown", "touchstart", "touchend", "touchmove"], u = function(e) {
        if (window.G_vmlCanvasManager)
            return !0;
        e = e || window.event;
        var t = e.toElement || e.relatedTarget || e.srcElement || e.target;
        return t && t.className.match(o.elementClassName)
    }, V = {resize: function(e) {
            e = e || window.event, this._lastHover = null, this._isMouseDown = 0, this.dispatch(c.RESIZE, e)
        },click: function(e, t) {
            if (u(e) || t) {
                e = this._zrenderEventFixed(e);
                var i = this._lastHover;
                (i && i.clickable || !i) && this._clickThreshold < 5 && this._dispatchAgency(i, c.CLICK, e), this._mousemoveHandler(e)
            }
        },dblclick: function(e, t) {
            if (u(e) || t) {
                e = e || window.event, e = this._zrenderEventFixed(e);
                var i = this._lastHover;
                (i && i.clickable || !i) && this._clickThreshold < 5 && this._dispatchAgency(i, c.DBLCLICK, e), this._mousemoveHandler(e)
            }
        },mousewheel: function(e, t) {
            if (u(e) || t) {
                e = this._zrenderEventFixed(e);
                var i = e.wheelDelta || -e.detail, n = i > 0 ? 1.1 : 1 / 1.1, a = !1, o = this._mouseX, r = this._mouseY;
                this.painter.eachBuildinLayer(function(t) {
                    var i = t.position;
                    if (t.zoomable) {
                        t.__zoom = t.__zoom || 1;
                        var l = t.__zoom;
                        l *= n, l = Math.max(Math.min(t.maxZoom, l), t.minZoom), n = l / t.__zoom, t.__zoom = l, i[0] -= (o - i[0]) * (n - 1), i[1] -= (r - i[1]) * (n - 1), t.scale[0] *= n, t.scale[1] *= n, t.dirty = !0, a = !0, s.stop(e)
                    }
                }), a && this.painter.refresh(), this._dispatchAgency(this._lastHover, c.MOUSEWHEEL, e), this._mousemoveHandler(e)
            }
        },mousemove: function(e, t) {
            if ((u(e) || t) && !this.painter.isLoading()) {
                e = this._zrenderEventFixed(e), this._lastX = this._mouseX, this._lastY = this._mouseY, this._mouseX = s.getX(e), this._mouseY = s.getY(e);
                var i = this._mouseX - this._lastX, n = this._mouseY - this._lastY;
                this._processDragStart(e), this._hasfound = 0, this._event = e, this._iterateAndFindHover(), this._hasfound || ((!this._draggingTarget || this._lastHover && this._lastHover != this._draggingTarget) && (this._processOutShape(e), this._processDragLeave(e)), this._lastHover = null, this.storage.delHover(), this.painter.clearHover());
                var a = "default";
                if (this._draggingTarget)
                    this.storage.drift(this._draggingTarget.id, i, n), this._draggingTarget.modSelf(), this.storage.addHover(this._draggingTarget), this._clickThreshold++;
                else if (this._isMouseDown) {
                    var o = !1;
                    this.painter.eachBuildinLayer(function(e) {
                        e.panable && (a = "move", e.position[0] += i, e.position[1] += n, o = !0, e.dirty = !0)
                    }), o && this.painter.refresh()
                }
                this._draggingTarget || this._hasfound && this._lastHover.draggable ? a = "move" : this._hasfound && this._lastHover.clickable && (a = "pointer"), this.root.style.cursor = a, this._dispatchAgency(this._lastHover, c.MOUSEMOVE, e), (this._draggingTarget || this._hasfound || this.storage.hasHoverShape()) && this.painter.refreshHover()
            }
        },mouseout: function(e, t) {
            if (u(e) || t) {
                e = this._zrenderEventFixed(e);
                var i = e.toElement || e.relatedTarget;
                if (i != this.root)
                    for (; i && 9 != i.nodeType; ) {
                        if (i == this.root)
                            return void this._mousemoveHandler(e);
                        i = i.parentNode
                    }
                e.zrenderX = this._lastX, e.zrenderY = this._lastY, this.root.style.cursor = "default", this._isMouseDown = 0, this._processOutShape(e), this._processDrop(e), this._processDragEnd(e), this.painter.isLoading() || this.painter.refreshHover(), this.dispatch(c.GLOBALOUT, e)
            }
        },mousedown: function(e, t) {
            if (u(e) || t) {
                if (this._clickThreshold = 0, 2 == this._lastDownButton)
                    return this._lastDownButton = e.button, void (this._mouseDownTarget = null);
                this._lastMouseDownMoment = new Date, e = this._zrenderEventFixed(e), this._isMouseDown = 1, this._mouseDownTarget = this._lastHover, this._dispatchAgency(this._lastHover, c.MOUSEDOWN, e), this._lastDownButton = e.button
            }
        },mouseup: function(e, t) {
            (u(e) || t) && (e = this._zrenderEventFixed(e), this.root.style.cursor = "default", this._isMouseDown = 0, this._mouseDownTarget = null, this._dispatchAgency(this._lastHover, c.MOUSEUP, e), this._processDrop(e), this._processDragEnd(e))
        },touchstart: function(e, t) {
            (u(e) || t) && (e = this._zrenderEventFixed(e, !0), this._lastTouchMoment = new Date, this._mobileFindFixed(e), this._mousedownHandler(e))
        },touchmove: function(e, t) {
            (u(e) || t) && (e = this._zrenderEventFixed(e, !0), this._mousemoveHandler(e), this._isDragging && s.stop(e))
        },touchend: function(e, t) {
            if (u(e) || t) {
                e = this._zrenderEventFixed(e, !0), this._mouseupHandler(e);
                var i = new Date;
                i - this._lastTouchMoment < c.touchClickDelay && (this._mobileFindFixed(e), this._clickHandler(e), i - this._lastClickMoment < c.touchClickDelay / 2 && (this._dblclickHandler(e), this._lastHover && this._lastHover.clickable && s.stop(e)), this._lastClickMoment = i), this.painter.clearHover()
            }
        }}, U = function(e, t, o) {
        m.call(this), this.root = e, this.storage = t, this.painter = o, this._lastX = this._lastY = this._mouseX = this._mouseY = 0, this._findHover = i(a, this), this._domHover = o.getDomHover(), n(this), window.addEventListener ? (window.addEventListener("resize", this._resizeHandler), r.os.tablet || r.os.phone ? (e.addEventListener("touchstart", this._touchstartHandler), e.addEventListener("touchmove", this._touchmoveHandler), e.addEventListener("touchend", this._touchendHandler)) : (e.addEventListener("click", this._clickHandler), e.addEventListener("dblclick", this._dblclickHandler), e.addEventListener("mousewheel", this._mousewheelHandler), e.addEventListener("mousemove", this._mousemoveHandler), e.addEventListener("mousedown", this._mousedownHandler), e.addEventListener("mouseup", this._mouseupHandler)), e.addEventListener("DOMMouseScroll", this._mousewheelHandler), e.addEventListener("mouseout", this._mouseoutHandler)) : (window.attachEvent("onresize", this._resizeHandler), e.attachEvent("onclick", this._clickHandler), e.ondblclick = this._dblclickHandler, e.attachEvent("onmousewheel", this._mousewheelHandler), e.attachEvent("onmousemove", this._mousemoveHandler), e.attachEvent("onmouseout", this._mouseoutHandler), e.attachEvent("onmousedown", this._mousedownHandler), e.attachEvent("onmouseup", this._mouseupHandler))
    };
    U.prototype.on = function(e, t, i) {
        return this.bind(e, t, i), this
    }, U.prototype.un = function(e, t) {
        return this.unbind(e, t), this
    }, U.prototype.trigger = function(e, t) {
        switch (e) {
            case c.RESIZE:
            case c.CLICK:
            case c.DBLCLICK:
            case c.MOUSEWHEEL:
            case c.MOUSEMOVE:
            case c.MOUSEDOWN:
            case c.MOUSEUP:
            case c.MOUSEOUT:
                this["_" + e + "Handler"](t, !0)
        }
    }, U.prototype.dispose = function() {
        var e = this.root;
        window.removeEventListener ? (window.removeEventListener("resize", this._resizeHandler), r.os.tablet || r.os.phone ? (e.removeEventListener("touchstart", this._touchstartHandler), e.removeEventListener("touchmove", this._touchmoveHandler), e.removeEventListener("touchend", this._touchendHandler)) : (e.removeEventListener("click", this._clickHandler), e.removeEventListener("dblclick", this._dblclickHandler), e.removeEventListener("mousewheel", this._mousewheelHandler), e.removeEventListener("mousemove", this._mousemoveHandler), e.removeEventListener("mousedown", this._mousedownHandler), e.removeEventListener("mouseup", this._mouseupHandler)), e.removeEventListener("DOMMouseScroll", this._mousewheelHandler), e.removeEventListener("mouseout", this._mouseoutHandler)) : (window.detachEvent("onresize", this._resizeHandler), e.detachEvent("onclick", this._clickHandler), e.detachEvent("dblclick", this._dblclickHandler), e.detachEvent("onmousewheel", this._mousewheelHandler), e.detachEvent("onmousemove", this._mousemoveHandler), e.detachEvent("onmouseout", this._mouseoutHandler), e.detachEvent("onmousedown", this._mousedownHandler), e.detachEvent("onmouseup", this._mouseupHandler)), this.root = this._domHover = this.storage = this.painter = null, this.un()
    }, U.prototype._processDragStart = function(e) {
        var t = this._lastHover;
        if (this._isMouseDown && t && t.draggable && !this._draggingTarget && this._mouseDownTarget == t) {
            if (t.dragEnableTime && new Date - this._lastMouseDownMoment < t.dragEnableTime)
                return;
            var i = t;
            this._draggingTarget = i, this._isDragging = 1, i.invisible = !0, this.storage.mod(i.id), this._dispatchAgency(i, c.DRAGSTART, e), this.painter.refresh()
        }
    }, U.prototype._processDragEnter = function(e) {
        this._draggingTarget && this._dispatchAgency(this._lastHover, c.DRAGENTER, e, this._draggingTarget)
    }, U.prototype._processDragOver = function(e) {
        this._draggingTarget && this._dispatchAgency(this._lastHover, c.DRAGOVER, e, this._draggingTarget)
    }, U.prototype._processDragLeave = function(e) {
        this._draggingTarget && this._dispatchAgency(this._lastHover, c.DRAGLEAVE, e, this._draggingTarget)
    }, U.prototype._processDrop = function(e) {
        this._draggingTarget && (this._draggingTarget.invisible = !1, this.storage.mod(this._draggingTarget.id), this.painter.refresh(), this._dispatchAgency(this._lastHover, c.DROP, e, this._draggingTarget))
    }, U.prototype._processDragEnd = function(e) {
        this._draggingTarget && (this._dispatchAgency(this._draggingTarget, c.DRAGEND, e), this._lastHover = null), this._isDragging = 0, this._draggingTarget = null
    }, U.prototype._processOverShape = function(e) {
        this._dispatchAgency(this._lastHover, c.MOUSEOVER, e)
    }, U.prototype._processOutShape = function(e) {
        this._dispatchAgency(this._lastHover, c.MOUSEOUT, e)
    }, U.prototype._dispatchAgency = function(e, t, i, n) {
        var a = "on" + t, o = {type: t,event: i,target: e,cancelBubble: !1}, r = e;
        for (n && (o.dragged = n); r && (r[a] && (o.cancelBubble = r[a](o)), r.dispatch(t, o), r = r.parent, !o.cancelBubble); )
            ;
        if (e)
            o.cancelBubble || this.dispatch(t, o);
        else if (!n) {
            var s = {type: t,event: i};
            this.dispatch(t, s), this.painter.eachOtherLayer(function(e) {
                "function" == typeof e[a] && e[a](s), e.dispatch && e.dispatch(t, s)
            })
        }
    }, U.prototype._iterateAndFindHover = function() {
        var e = d.create();
        return function() {
            for (var t, i, n = this.storage.getShapeList(), a = [0, 0], o = n.length - 1; o >= 0; o--) {
                var r = n[o];
                if (t !== r.zlevel && (i = this.painter.getLayer(r.zlevel, i), a[0] = this._mouseX, a[1] = this._mouseY, i.needTransform && (d.invert(e, i.transform), h.applyTransform(a, a, e))), this._findHover(r, a[0], a[1]))
                    break
            }
        }
    }();
    var g = [{x: 10}, {x: -20}, {x: 10,y: 10}, {y: -20}];
    return U.prototype._mobileFindFixed = function(e) {
        this._lastHover = null, this._mouseX = e.zrenderX, this._mouseY = e.zrenderY, this._event = e, this._iterateAndFindHover();
        for (var t = 0; !this._lastHover && t < g.length; t++) {
            var i = g[t];
            i.x && (this._mouseX += i.x), i.y && (this._mouseY += i.y), this._iterateAndFindHover()
        }
        this._lastHover && (e.zrenderX = this._mouseX, e.zrenderY = this._mouseY)
    }, U.prototype._zrenderEventFixed = function(e, t) {
        if (e.zrenderFixed)
            return e;
        if (t) {
            var i = "touchend" != e.type ? e.targetTouches[0] : e.changedTouches[0];
            if (i) {
                var n = this.painter._domRoot.getBoundingClientRect();
                e.zrenderX = i.clientX - n.left, e.zrenderY = i.clientY - n.top
            }
        } else {
            e = e || window.event;
            var a = e.toElement || e.relatedTarget || e.srcElement || e.target;
            a && a != this._domHover && (e.zrenderX = ("undefined" != typeof e.offsetX ? e.offsetX : e.layerX) + a.offsetLeft, e.zrenderY = ("undefined" != typeof e.offsetY ? e.offsetY : e.layerY) + a.offsetTop)
        }
        return e.zrenderFixed = 1, e
    }, l.merge(U.prototype, m.prototype, !0), U
}), define("zrender/Painter", ["require", "./config", "./tool/util", "./tool/log", "./loadingEffect/Base", "./Layer", "./shape/Image"], function(e) {
    "use strict";
    function t() {
        return !1
    }
    function i() {
    }
    function n(e) {
        return e ? e.isBuildin ? !0 : "function" != typeof e.resize || "function" != typeof e.refresh ? !1 : !0 : !1
    }
    var a = e("./config"), o = e("./tool/util"), r = e("./tool/log"), s = e("./loadingEffect/Base"), l = e("./Layer"), h = function(e, i) {
        this.root = e, e.style["-webkit-tap-highlight-color"] = "transparent", e.style["-webkit-user-select"] = "none", e.style["user-select"] = "none", e.style["-webkit-touch-callout"] = "none", this.storage = i, e.innerHTML = "", this._width = this._getWidth(), this._height = this._getHeight();
        var n = document.createElement("div");
        this._domRoot = n, n.style.position = "relative", n.style.overflow = "hidden", n.style.width = this._width + "px", n.style.height = this._height + "px", e.appendChild(n), this._layers = {}, this._zlevelList = [], this._layerConfig = {}, this._loadingEffect = new s({}), this.shapeToImage = this._createShapeToImageProcessor(), this._bgDom = document.createElement("div"), this._bgDom.style.cssText = ["position:absolute;left:0px;top:0px;width:", this._width, "px;height:", this._height + "px;", "-webkit-user-select:none;user-select;none;", "-webkit-touch-callout:none;"].join(""), this._bgDom.setAttribute("data-zr-dom-id", "bg"), this._bgDom.className = a.elementClassName, n.appendChild(this._bgDom), this._bgDom.onselectstart = t;
        var o = new l("_zrender_hover_", this);
        this._layers.hover = o, n.appendChild(o.dom), o.initContext(), o.dom.onselectstart = t, o.dom.style["-webkit-user-select"] = "none", o.dom.style["user-select"] = "none", o.dom.style["-webkit-touch-callout"] = "none", this.refreshNextFrame = null
    };
    return h.prototype.render = function(e) {
        return this.isLoading() && this.hideLoading(), this.refresh(e, !0), this
    }, h.prototype.refresh = function(e, t) {
        var i = this.storage.getShapeList(!0);
        this._paintList(i, t);
        for (var n = 0; n < this._zlevelList.length; n++) {
            var a = this._zlevelList[n], o = this._layers[a];
            !o.isBuildin && o.refresh && o.refresh()
        }
        return "function" == typeof e && e(), this
    }, h.prototype._preProcessLayer = function(e) {
        e.unusedCount++, e.updateTransform()
    }, h.prototype._postProcessLayer = function(e) {
        e.dirty = !1, 1 == e.unusedCount && e.clear()
    }, h.prototype._paintList = function(e, t) {
        "undefined" == typeof t && (t = !1), this._updateLayerStatus(e);
        var i, n, o;
        this.eachBuildinLayer(this._preProcessLayer);
        for (var s = 0, l = e.length; l > s; s++) {
            var h = e[s];
            if (n !== h.zlevel && (i && (i.needTransform && o.restore(), o.flush && o.flush()), n = h.zlevel, i = this.getLayer(n), i.isBuildin || r("ZLevel " + n + " has been used by unkown layer " + i.id), o = i.ctx, i.unusedCount = 0, (i.dirty || t) && i.clear(), i.needTransform && (o.save(), i.setTransform(o))), (i.dirty || t) && !h.invisible && (!h.onbrush || h.onbrush && !h.onbrush(o, !1)))
                if (a.catchBrushException)
                    try {
                        h.brush(o, !1, this.refreshNextFrame)
                    } catch (d) {
                        r(d, "brush error of " + h.type, h)
                    }
                else
                    h.brush(o, !1, this.refreshNextFrame);
            h.__dirty = !1
        }
        i && (i.needTransform && o.restore(), o.flush && o.flush()), this.eachBuildinLayer(this._postProcessLayer)
    }, h.prototype.getLayer = function(e) {
        var t = this._layers[e];
        return t || (t = new l(e, this), t.isBuildin = !0, this._layerConfig[e] && o.merge(t, this._layerConfig[e], !0), t.updateTransform(), this.insertLayer(e, t), t.initContext()), t
    }, h.prototype.insertLayer = function(e, t) {
        if (this._layers[e])
            return void r("ZLevel " + e + " has been used already");
        if (!n(t))
            return void r("Layer of zlevel " + e + " is not valid");
        var i = this._zlevelList.length, a = null, o = -1;
        if (i > 0 && e > this._zlevelList[0]) {
            for (o = 0; i - 1 > o && !(this._zlevelList[o] < e && this._zlevelList[o + 1] > e); o++)
                ;
            a = this._layers[this._zlevelList[o]]
        }
        this._zlevelList.splice(o + 1, 0, e);
        var s = a ? a.dom : this._bgDom;
        s.nextSibling ? s.parentNode.insertBefore(t.dom, s.nextSibling) : s.parentNode.appendChild(t.dom), this._layers[e] = t
    }, h.prototype.eachLayer = function(e, t) {
        for (var i = 0; i < this._zlevelList.length; i++) {
            var n = this._zlevelList[i];
            e.call(t, this._layers[n], n)
        }
    }, h.prototype.eachBuildinLayer = function(e, t) {
        for (var i = 0; i < this._zlevelList.length; i++) {
            var n = this._zlevelList[i], a = this._layers[n];
            a.isBuildin && e.call(t, a, n)
        }
    }, h.prototype.eachOtherLayer = function(e, t) {
        for (var i = 0; i < this._zlevelList.length; i++) {
            var n = this._zlevelList[i], a = this._layers[n];
            a.isBuildin || e.call(t, a, n)
        }
    }, h.prototype.getLayers = function() {
        return this._layers
    }, h.prototype._updateLayerStatus = function(e) {
        var t = this._layers, i = {};
        this.eachBuildinLayer(function(e, t) {
            i[t] = e.elCount, e.elCount = 0
        });
        for (var n = 0, a = e.length; a > n; n++) {
            var o = e[n], r = o.zlevel, s = t[r];
            if (s) {
                if (s.elCount++, s.dirty)
                    continue;
                s.dirty = o.__dirty
            }
        }
        this.eachBuildinLayer(function(e, t) {
            i[t] !== e.elCount && (e.dirty = !0)
        })
    }, h.prototype.refreshShapes = function(e, t) {
        for (var i = 0, n = e.length; n > i; i++) {
            var a = e[i];
            a.modSelf()
        }
        return this.refresh(t), this
    }, h.prototype.setLoadingEffect = function(e) {
        return this._loadingEffect = e, this
    }, h.prototype.clear = function() {
        return this.eachBuildinLayer(this._clearLayer), this
    }, h.prototype._clearLayer = function(e) {
        e.clear()
    }, h.prototype.modLayer = function(e, t) {
        if (t) {
            this._layerConfig[e] ? o.merge(this._layerConfig[e], t, !0) : this._layerConfig[e] = t;
            var i = this._layers[e];
            i && o.merge(i, this._layerConfig[e], !0)
        }
    }, h.prototype.delLayer = function(e) {
        var t = this._layers[e];
        t && (this.modLayer(e, {position: t.position,rotation: t.rotation,scale: t.scale}), t.dom.parentNode.removeChild(t.dom), delete this._layers[e], this._zlevelList.splice(o.indexOf(this._zlevelList, e), 1))
    }, h.prototype.refreshHover = function() {
        this.clearHover();
        for (var e = this.storage.getHoverShapes(!0), t = 0, i = e.length; i > t; t++)
            this._brushHover(e[t]);
        var n = this._layers.hover.ctx;
        return n.flush && n.flush(), this.storage.delHover(), this
    }, h.prototype.clearHover = function() {
        var e = this._layers.hover;
        return e && e.clear(), this
    }, h.prototype.showLoading = function(e) {
        return this._loadingEffect && this._loadingEffect.stop(), e && this.setLoadingEffect(e), this._loadingEffect.start(this), this.loading = !0, this
    }, h.prototype.hideLoading = function() {
        return this._loadingEffect.stop(), this.clearHover(), this.loading = !1, this
    }, h.prototype.isLoading = function() {
        return this.loading
    }, h.prototype.resize = function() {
        var e = this._domRoot;
        e.style.display = "none";
        var t = this._getWidth(), i = this._getHeight();
        if (e.style.display = "", this._width != t || i != this._height) {
            this._width = t, this._height = i, e.style.width = t + "px", e.style.height = i + "px";
            for (var n in this._layers)
                this._layers[n].resize(t, i);
            this.refresh(null, !0)
        }
        return this
    }, h.prototype.clearLayer = function(e) {
        var t = this._layers[e];
        t && t.clear()
    }, h.prototype.dispose = function() {
        this.isLoading() && this.hideLoading(), this.root.innerHTML = "", this.root = this.storage = this._domRoot = this._layers = null
    }, h.prototype.getDomHover = function() {
        return this._layers.hover.dom
    }, h.prototype.toDataURL = function(e, t, i) {
        if (window.G_vmlCanvasManager)
            return null;
        var n = new l("image", this);
        this._bgDom.appendChild(n.dom), n.initContext();
        var o = n.ctx;
        n.clearColor = t || "#fff", n.clear();
        var s = this;
        this.storage.iterShape(function(e) {
            if (!e.invisible && (!e.onbrush || e.onbrush && !e.onbrush(o, !1)))
                if (a.catchBrushException)
                    try {
                        e.brush(o, !1, s.refreshNextFrame)
                    } catch (t) {
                        r(t, "brush error of " + e.type, e)
                    }
                else
                    e.brush(o, !1, s.refreshNextFrame)
        }, {normal: "up",update: !0});
        var h = n.dom.toDataURL(e, i);
        return o = null, this._bgDom.removeChild(n.dom), h
    }, h.prototype.getWidth = function() {
        return this._width
    }, h.prototype.getHeight = function() {
        return this._height
    }, h.prototype._getWidth = function() {
        var e = this.root, t = e.currentStyle || document.defaultView.getComputedStyle(e);
        return ((e.clientWidth || parseInt(t.width, 10)) - parseInt(t.paddingLeft, 10) - parseInt(t.paddingRight, 10)).toFixed(0) - 0
    }, h.prototype._getHeight = function() {
        var e = this.root, t = e.currentStyle || document.defaultView.getComputedStyle(e);
        return ((e.clientHeight || parseInt(t.height, 10)) - parseInt(t.paddingTop, 10) - parseInt(t.paddingBottom, 10)).toFixed(0) - 0
    }, h.prototype._brushHover = function(e) {
        var t = this._layers.hover.ctx;
        if (!e.onbrush || e.onbrush && !e.onbrush(t, !0)) {
            var i = this.getLayer(e.zlevel);
            if (i.needTransform && (t.save(), i.setTransform(t)), a.catchBrushException)
                try {
                    e.brush(t, !0, this.refreshNextFrame)
                } catch (n) {
                    r(n, "hoverBrush error of " + e.type, e)
                }
            else
                e.brush(t, !0, this.refreshNextFrame);
            i.needTransform && t.restore()
        }
    }, h.prototype._shapeToImage = function(t, i, n, a, o) {
        var r = document.createElement("canvas"), s = r.getContext("2d");
        r.style.width = n + "px", r.style.height = a + "px", r.setAttribute("width", n * o), r.setAttribute("height", a * o), s.clearRect(0, 0, n * o, a * o);
        var l = {position: i.position,rotation: i.rotation,scale: i.scale};
        i.position = [0, 0, 0], i.rotation = 0, i.scale = [1, 1], i && i.brush(s, !1);
        var h = e("./shape/Image"), d = new h({id: t,style: {x: 0,y: 0,image: r}});
        return null != l.position && (d.position = i.position = l.position), null != l.rotation && (d.rotation = i.rotation = l.rotation), null != l.scale && (d.scale = i.scale = l.scale), d
    }, h.prototype._createShapeToImageProcessor = function() {
        if (window.G_vmlCanvasManager)
            return i;
        var e = this;
        return function(t, i, n, o) {
            return e._shapeToImage(t, i, n, o, a.devicePixelRatio)
        }
    }, h
}), define("zrender/Storage", ["require", "./tool/util", "./Group"], function(e) {
    "use strict";
    function t(e, t) {
        return e.zlevel == t.zlevel ? e.z == t.z ? e.__renderidx - t.__renderidx : e.z - t.z : e.zlevel - t.zlevel
    }
    var i = e("./tool/util"), n = e("./Group"), a = {hover: !1,normal: "down",update: !1}, o = function() {
        this._elements = {}, this._hoverElements = [], this._roots = [], this._shapeList = [], this._shapeListOffset = 0
    };
    return o.prototype.iterShape = function(e, t) {
        if (t || (t = a), t.hover)
            for (var i = 0, n = this._hoverElements.length; n > i; i++) {
                var o = this._hoverElements[i];
                if (o.updateTransform(), e(o))
                    return this
            }
        switch (t.update && this.updateShapeList(), t.normal) {
            case "down":
                for (var n = this._shapeList.length; n--; )
                    if (e(this._shapeList[n]))
                        return this;
                break;
            default:
                for (var i = 0, n = this._shapeList.length; n > i; i++)
                    if (e(this._shapeList[i]))
                        return this
        }
        return this
    }, o.prototype.getHoverShapes = function(e) {
        for (var i = [], n = 0, a = this._hoverElements.length; a > n; n++) {
            i.push(this._hoverElements[n]);
            var o = this._hoverElements[n].hoverConnect;
            if (o) {
                var r;
                o = o instanceof Array ? o : [o];
                for (var s = 0, l = o.length; l > s; s++)
                    r = o[s].id ? o[s] : this.get(o[s]), r && i.push(r)
            }
        }
        if (i.sort(t), e)
            for (var n = 0, a = i.length; a > n; n++)
                i[n].updateTransform();
        return i
    }, o.prototype.getShapeList = function(e) {
        return e && this.updateShapeList(), this._shapeList
    }, o.prototype.updateShapeList = function() {
        this._shapeListOffset = 0;
        for (var e = 0, i = this._roots.length; i > e; e++) {
            var n = this._roots[e];
            this._updateAndAddShape(n)
        }
        this._shapeList.length = this._shapeListOffset;
        for (var e = 0, i = this._shapeList.length; i > e; e++)
            this._shapeList[e].__renderidx = e;
        this._shapeList.sort(t)
    }, o.prototype._updateAndAddShape = function(e, t) {
        if (!e.ignore)
            if (e.updateTransform(), e.clipShape && (e.clipShape.parent = e, e.clipShape.updateTransform(), t ? (t = t.slice(), t.push(e.clipShape)) : t = [e.clipShape]), "group" == e.type) {
                for (var i = 0; i < e._children.length; i++) {
                    var n = e._children[i];
                    n.__dirty = e.__dirty || n.__dirty, this._updateAndAddShape(n, t)
                }
                e.__dirty = !1
            } else
                e.__clipShapes = t, this._shapeList[this._shapeListOffset++] = e
    }, o.prototype.mod = function(e, t) {
        if ("string" == typeof e && (e = this._elements[e]), e && (e.modSelf(), t))
            if (t.parent || t._storage || t.__clipShapes) {
                var n = {};
                for (var a in t)
                    "parent" !== a && "_storage" !== a && "__clipShapes" !== a && t.hasOwnProperty(a) && (n[a] = t[a]);
                i.merge(e, n, !0)
            } else
                i.merge(e, t, !0);
        return this
    }, o.prototype.drift = function(e, t, i) {
        var n = this._elements[e];
        return n && (n.needTransform = !0, "horizontal" === n.draggable ? i = 0 : "vertical" === n.draggable && (t = 0), (!n.ondrift || n.ondrift && !n.ondrift(t, i)) && n.drift(t, i)), this
    }, o.prototype.addHover = function(e) {
        return e.updateNeedTransform(), this._hoverElements.push(e), this
    }, o.prototype.delHover = function() {
        return this._hoverElements = [], this
    }, o.prototype.hasHoverShape = function() {
        return this._hoverElements.length > 0
    }, o.prototype.addRoot = function(e) {
        this._elements[e.id] || (e instanceof n && e.addChildrenToStorage(this), this.addToMap(e), this._roots.push(e))
    }, o.prototype.delRoot = function(e) {
        if ("undefined" == typeof e) {
            for (var t = 0; t < this._roots.length; t++) {
                var a = this._roots[t];
                a instanceof n && a.delChildrenFromStorage(this)
            }
            return this._elements = {}, this._hoverElements = [], this._roots = [], this._shapeList = [], void (this._shapeListOffset = 0)
        }
        if (e instanceof Array)
            for (var t = 0, o = e.length; o > t; t++)
                this.delRoot(e[t]);
        else {
            var r;
            r = "string" == typeof e ? this._elements[e] : e;
            var s = i.indexOf(this._roots, r);
            s >= 0 && (this.delFromMap(r.id), this._roots.splice(s, 1), r instanceof n && r.delChildrenFromStorage(this))
        }
    }, o.prototype.addToMap = function(e) {
        return e instanceof n && (e._storage = this), e.modSelf(), this._elements[e.id] = e, this
    }, o.prototype.get = function(e) {
        return this._elements[e]
    }, o.prototype.delFromMap = function(e) {
        var t = this._elements[e];
        return t && (delete this._elements[e], t instanceof n && (t._storage = null)), this
    }, o.prototype.dispose = function() {
        this._elements = this._renderList = this._roots = this._hoverElements = null
    }, o
}), define("zrender/animation/Animation", ["require", "./Clip", "../tool/color", "../tool/util", "../tool/event"], function(e) {
    "use strict";
    function t(e, t) {
        return e[t]
    }
    function i(e, t, i) {
        e[t] = i
    }
    function n(e, t, i) {
        return (t - e) * i + e
    }
    function a(e, t, i, a, o) {
        var r = e.length;
        if (1 == o)
            for (var s = 0; r > s; s++)
                a[s] = n(e[s], t[s], i);
        else
            for (var l = e[0].length, s = 0; r > s; s++)
                for (var h = 0; l > h; h++)
                    a[s][h] = n(e[s][h], t[s][h], i)
    }
    function o(e) {
        switch (typeof e) {
            case "undefined":
            case "string":
                return !1
        }
        return "undefined" != typeof e.length
    }
    function r(e, t, i, n, a, o, r, l, h) {
        var d = e.length;
        if (1 == h)
            for (var c = 0; d > c; c++)
                l[c] = s(e[c], t[c], i[c], n[c], a, o, r);
        else
            for (var m = e[0].length, c = 0; d > c; c++)
                for (var p = 0; m > p; p++)
                    l[c][p] = s(e[c][p], t[c][p], i[c][p], n[c][p], a, o, r)
    }
    function s(e, t, i, n, a, o, r) {
        var s = .5 * (i - e), l = .5 * (n - t);
        return (2 * (t - i) + s + l) * r + (-3 * (t - i) - 2 * s - l) * o + s * a + t
    }
    function l(e) {
        if (o(e)) {
            var t = e.length;
            if (o(e[0])) {
                for (var i = [], n = 0; t > n; n++)
                    i.push(V.call(e[n]));
                return i
            }
            return V.call(e)
        }
        return e
    }
    function h(e) {
        return e[0] = Math.floor(e[0]), e[1] = Math.floor(e[1]), e[2] = Math.floor(e[2]), "rgba(" + e.join(",") + ")"
    }
    var d = e("./Clip"), c = e("../tool/color"), m = e("../tool/util"), p = e("../tool/event").Dispatcher, u = window.requestAnimationFrame || window.msRequestAnimationFrame || window.mozRequestAnimationFrame || window.webkitRequestAnimationFrame || function(e) {
        setTimeout(e, 16)
    }, V = Array.prototype.slice, U = function(e) {
        e = e || {}, this.stage = e.stage || {}, this.onframe = e.onframe || function() {
        }, this._clips = [], this._running = !1, this._time = 0, p.call(this)
    };
    U.prototype = {add: function(e) {
            this._clips.push(e)
        },remove: function(e) {
            if (e.__inStep)
                e.__needsRemove = !0;
            else {
                var t = m.indexOf(this._clips, e);
                t >= 0 && this._clips.splice(t, 1)
            }
        },_update: function() {
            for (var e = (new Date).getTime(), t = e - this._time, i = this._clips, n = i.length, a = [], o = [], r = 0; n > r; r++) {
                var s = i[r];
                s.__inStep = !0;
                var l = s.step(e);
                s.__inStep = !1, l && (a.push(l), o.push(s))
            }
            for (var r = 0; n > r; )
                i[r].__needsRemove ? (i[r] = i[n - 1], i.pop(), n--) : r++;
            n = a.length;
            for (var r = 0; n > r; r++)
                o[r].fire(a[r]);
            this._time = e, this.onframe(t), this.dispatch("frame", t), this.stage.update && this.stage.update()
        },start: function() {
            function e() {
                t._running && (u(e), t._update())
            }
            var t = this;
            this._running = !0, this._time = (new Date).getTime(), u(e)
        },stop: function() {
            this._running = !1
        },clear: function() {
            this._clips = []
        },animate: function(e, t) {
            t = t || {};
            var i = new g(e, t.loop, t.getter, t.setter);
            return i.animation = this, i
        },constructor: U}, m.merge(U.prototype, p.prototype, !0);
    var g = function(e, n, a, o) {
        this._tracks = {}, this._target = e, this._loop = n || !1, this._getter = a || t, this._setter = o || i, this._clipCount = 0, this._delay = 0, this._doneList = [], this._onframeList = [], this._clipList = []
    };
    return g.prototype = {when: function(e, t) {
            for (var i in t)
                this._tracks[i] || (this._tracks[i] = [], 0 !== e && this._tracks[i].push({time: 0,value: l(this._getter(this._target, i))})), this._tracks[i].push({time: parseInt(e, 10),value: t[i]});
            return this
        },during: function(e) {
            return this._onframeList.push(e), this
        },start: function(e) {
            var t = this, i = this._setter, l = this._getter, m = "spline" === e, p = function() {
                if (t._clipCount--, 0 === t._clipCount) {
                    t._tracks = {};
                    for (var e = t._doneList.length, i = 0; e > i; i++)
                        t._doneList[i].call(t)
                }
            }, u = function(u, V) {
                var U = u.length;
                if (U) {
                    var g = u[0].value, f = o(g), y = !1, b = f && o(g[0]) ? 2 : 1;
                    u.sort(function(e, t) {
                        return e.time - t.time
                    });
                    var _;
                    if (U) {
                        _ = u[U - 1].time;
                        for (var x = [], k = [], v = 0; U > v; v++) {
                            x.push(u[v].time / _);
                            var L = u[v].value;
                            "string" == typeof L && (L = c.toArray(L), 0 === L.length && (L[0] = L[1] = L[2] = 0, L[3] = 1), y = !0), k.push(L)
                        }
                        var w, v, W, X, I, S, K, C = 0, T = 0;
                        if (y)
                            var E = [0, 0, 0, 0];
                        var z = function(e, o) {
                            if (T > o) {
                                for (w = Math.min(C + 1, U - 1), v = w; v >= 0 && !(x[v] <= o); v--)
                                    ;
                                v = Math.min(v, U - 2)
                            } else {
                                for (v = C; U > v && !(x[v] > o); v++)
                                    ;
                                v = Math.min(v - 1, U - 2)
                            }
                            C = v, T = o;
                            var d = x[v + 1] - x[v];
                            if (0 !== d) {
                                if (W = (o - x[v]) / d, m)
                                    if (I = k[v], X = k[0 === v ? v : v - 1], S = k[v > U - 2 ? U - 1 : v + 1], K = k[v > U - 3 ? U - 1 : v + 2], f)
                                        r(X, I, S, K, W, W * W, W * W * W, l(e, V), b);
                                    else {
                                        var c;
                                        y ? (c = r(X, I, S, K, W, W * W, W * W * W, E, 1), c = h(E)) : c = s(X, I, S, K, W, W * W, W * W * W), i(e, V, c)
                                    }
                                else if (f)
                                    a(k[v], k[v + 1], W, l(e, V), b);
                                else {
                                    var c;
                                    y ? (a(k[v], k[v + 1], W, E, 1), c = h(E)) : c = n(k[v], k[v + 1], W), i(e, V, c)
                                }
                                for (v = 0; v < t._onframeList.length; v++)
                                    t._onframeList[v](e, o);
                            
                            }
                        }, A = new d({target: t._target,life: _,loop: t._loop,delay: t._delay,onframe: z,ondestroy: p});
                        e && "spline" !== e && (A.easing = e), t._clipList.push(A), t._clipCount++, t.animation.add(A)
                    }
                }
            };
            for (var V in this._tracks)
                u(this._tracks[V], V);
            return this
        },stop: function() {
            for (var e = 0; e < this._clipList.length; e++) {
                var t = this._clipList[e];
                this.animation.remove(t)
            }
            this._clipList = []
        },delay: function(e) {
            return this._delay = e, this
        },done: function(e) {
            return e && this._doneList.push(e), this
        }}, U
}), define("zrender/tool/vector", [], function() {
    var e = "undefined" == typeof Float32Array ? Array : Float32Array, t = {create: function(t, i) {
            var n = new e(2);
            return n[0] = t || 0, n[1] = i || 0, n
        },copy: function(e, t) {
            return e[0] = t[0], e[1] = t[1], e
        },clone: function(t) {
            var i = new e(2);
            return i[0] = t[0], i[1] = t[1], i
        },set: function(e, t, i) {
            return e[0] = t, e[1] = i, e
        },add: function(e, t, i) {
            return e[0] = t[0] + i[0], e[1] = t[1] + i[1], e
        },scaleAndAdd: function(e, t, i, n) {
            return e[0] = t[0] + i[0] * n, e[1] = t[1] + i[1] * n, e
        },sub: function(e, t, i) {
            return e[0] = t[0] - i[0], e[1] = t[1] - i[1], e
        },len: function(e) {
            return Math.sqrt(this.lenSquare(e))
        },lenSquare: function(e) {
            return e[0] * e[0] + e[1] * e[1]
        },mul: function(e, t, i) {
            return e[0] = t[0] * i[0], e[1] = t[1] * i[1], e
        },div: function(e, t, i) {
            return e[0] = t[0] / i[0], e[1] = t[1] / i[1], e
        },dot: function(e, t) {
            return e[0] * t[0] + e[1] * t[1]
        },scale: function(e, t, i) {
            return e[0] = t[0] * i, e[1] = t[1] * i, e
        },normalize: function(e, i) {
            var n = t.len(i);
            return 0 === n ? (e[0] = 0, e[1] = 0) : (e[0] = i[0] / n, e[1] = i[1] / n), e
        },distance: function(e, t) {
            return Math.sqrt((e[0] - t[0]) * (e[0] - t[0]) + (e[1] - t[1]) * (e[1] - t[1]))
        },distanceSquare: function(e, t) {
            return (e[0] - t[0]) * (e[0] - t[0]) + (e[1] - t[1]) * (e[1] - t[1])
        },negate: function(e, t) {
            return e[0] = -t[0], e[1] = -t[1], e
        },lerp: function(e, t, i, n) {
            return e[0] = t[0] + n * (i[0] - t[0]), e[1] = t[1] + n * (i[1] - t[1]), e
        },applyTransform: function(e, t, i) {
            var n = t[0], a = t[1];
            return e[0] = i[0] * n + i[2] * a + i[4], e[1] = i[1] * n + i[3] * a + i[5], e
        },min: function(e, t, i) {
            return e[0] = Math.min(t[0], i[0]), e[1] = Math.min(t[1], i[1]), e
        },max: function(e, t, i) {
            return e[0] = Math.max(t[0], i[0]), e[1] = Math.max(t[1], i[1]), e
        }};
    return t.length = t.len, t.lengthSquare = t.lenSquare, t.dist = t.distance, t.distSquare = t.distanceSquare, t
}), define("zrender/tool/matrix", [], function() {
    var e = "undefined" == typeof Float32Array ? Array : Float32Array, t = {create: function() {
            var i = new e(6);
            return t.identity(i), i
        },identity: function(e) {
            return e[0] = 1, e[1] = 0, e[2] = 0, e[3] = 1, e[4] = 0, e[5] = 0, e
        },copy: function(e, t) {
            return e[0] = t[0], e[1] = t[1], e[2] = t[2], e[3] = t[3], e[4] = t[4], e[5] = t[5], e
        },mul: function(e, t, i) {
            return e[0] = t[0] * i[0] + t[2] * i[1], e[1] = t[1] * i[0] + t[3] * i[1], e[2] = t[0] * i[2] + t[2] * i[3], e[3] = t[1] * i[2] + t[3] * i[3], e[4] = t[0] * i[4] + t[2] * i[5] + t[4], e[5] = t[1] * i[4] + t[3] * i[5] + t[5], e
        },translate: function(e, t, i) {
            return e[0] = t[0], e[1] = t[1], e[2] = t[2], e[3] = t[3], e[4] = t[4] + i[0], e[5] = t[5] + i[1], e
        },rotate: function(e, t, i) {
            var n = t[0], a = t[2], o = t[4], r = t[1], s = t[3], l = t[5], h = Math.sin(i), d = Math.cos(i);
            return e[0] = n * d + r * h, e[1] = -n * h + r * d, e[2] = a * d + s * h, e[3] = -a * h + d * s, e[4] = d * o + h * l, e[5] = d * l - h * o, e
        },scale: function(e, t, i) {
            var n = i[0], a = i[1];
            return e[0] = t[0] * n, e[1] = t[1] * a, e[2] = t[2] * n, e[3] = t[3] * a, e[4] = t[4] * n, e[5] = t[5] * a, e
        },invert: function(e, t) {
            var i = t[0], n = t[2], a = t[4], o = t[1], r = t[3], s = t[5], l = i * r - o * n;
            return l ? (l = 1 / l, e[0] = r * l, e[1] = -o * l, e[2] = -n * l, e[3] = i * l, e[4] = (n * s - r * a) * l, e[5] = (o * a - i * s) * l, e) : null
        }};
    return t
}), define("zrender/loadingEffect/Base", ["require", "../tool/util", "../shape/Text", "../shape/Rectangle"], function(e) {
    function t(e) {
        this.setOptions(e)
    }
    var i = e("../tool/util"), n = e("../shape/Text"), a = e("../shape/Rectangle"), o = "Loading...", r = "normal 16px Arial";
    return t.prototype.createTextShape = function(e) {
        return new n({highlightStyle: i.merge({x: this.canvasWidth / 2,y: this.canvasHeight / 2,text: o,textAlign: "center",textBaseline: "middle",textFont: r,color: "#333",brushType: "fill"}, e, !0)})
    }, t.prototype.createBackgroundShape = function(e) {
        return new a({highlightStyle: {x: 0,y: 0,width: this.canvasWidth,height: this.canvasHeight,brushType: "fill",color: e}})
    }, t.prototype.start = function(e) {
        function t(t) {
            e.storage.addHover(t)
        }
        function i() {
            e.refreshHover()
        }
        this.canvasWidth = e._width, this.canvasHeight = e._height, this.loadingTimer = this._start(t, i)
    }, t.prototype._start = function() {
        return setInterval(function() {
        }, 1e4)
    }, t.prototype.stop = function() {
        clearInterval(this.loadingTimer)
    }, t.prototype.setOptions = function(e) {
        this.options = e || {}
    }, t.prototype.adjust = function(e, t) {
        return e <= t[0] ? e = t[0] : e >= t[1] && (e = t[1]), e
    }, t.prototype.getLocation = function(e, t, i) {
        var n = null != e.x ? e.x : "center";
        switch (n) {
            case "center":
                n = Math.floor((this.canvasWidth - t) / 2);
                break;
            case "left":
                n = 0;
                break;
            case "right":
                n = this.canvasWidth - t
        }
        var a = null != e.y ? e.y : "center";
        switch (a) {
            case "center":
                a = Math.floor((this.canvasHeight - i) / 2);
                break;
            case "top":
                a = 0;
                break;
            case "bottom":
                a = this.canvasHeight - i
        }
        return {x: n,y: a,width: t,height: i}
    }, t
}), define("zrender/Layer", ["require", "./mixin/Transformable", "./tool/util", "./config"], function(e) {
    function t() {
        return !1
    }
    function i(e, t, i) {
        var n = document.createElement(t), a = i.getWidth(), o = i.getHeight();
        return n.style.position = "absolute", n.style.left = 0, n.style.top = 0, n.style.width = a + "px", n.style.height = o + "px", n.width = a * r.devicePixelRatio, n.height = o * r.devicePixelRatio, n.setAttribute("data-zr-dom-id", e), n
    }
    var n = e("./mixin/Transformable"), a = e("./tool/util"), o = window.G_vmlCanvasManager, r = e("./config"), s = function(e, a) {
        this.id = e, this.dom = i(e, "canvas", a), this.dom.onselectstart = t, this.dom.style["-webkit-user-select"] = "none", this.dom.style["user-select"] = "none", this.dom.style["-webkit-touch-callout"] = "none", this.dom.style["-webkit-tap-highlight-color"] = "rgba(0,0,0,0)", this.dom.className = r.elementClassName, o && o.initElement(this.dom), this.domBack = null, this.ctxBack = null, this.painter = a, this.unusedCount = 0, this.config = null, this.dirty = !0, this.elCount = 0, this.clearColor = 0, this.motionBlur = !1, this.lastFrameAlpha = .7, this.zoomable = !1, this.panable = !1, this.maxZoom = 1 / 0, this.minZoom = 0, n.call(this)
    };
    return s.prototype.initContext = function() {
        this.ctx = this.dom.getContext("2d");
        var e = r.devicePixelRatio;
        1 != e && this.ctx.scale(e, e)
    }, s.prototype.createBackBuffer = function() {
        if (!o) {
            this.domBack = i("back-" + this.id, "canvas", this.painter), this.ctxBack = this.domBack.getContext("2d");
            var e = r.devicePixelRatio;
            1 != e && this.ctxBack.scale(e, e)
        }
    }, s.prototype.resize = function(e, t) {
        var i = r.devicePixelRatio;
        this.dom.style.width = e + "px", this.dom.style.height = t + "px", this.dom.setAttribute("width", e * i), this.dom.setAttribute("height", t * i), 1 != i && this.ctx.scale(i, i), this.domBack && (this.domBack.setAttribute("width", e * i), this.domBack.setAttribute("height", t * i), 1 != i && this.ctxBack.scale(i, i))
    }, s.prototype.clear = function() {
        var e = this.dom, t = this.ctx, i = e.width, n = e.height, a = this.clearColor && !o, s = this.motionBlur && !o, l = this.lastFrameAlpha, h = r.devicePixelRatio;
        if (s && (this.domBack || this.createBackBuffer(), this.ctxBack.globalCompositeOperation = "copy", this.ctxBack.drawImage(e, 0, 0, i / h, n / h)), t.clearRect(0, 0, i / h, n / h), a && (t.save(), t.fillStyle = this.clearColor, t.fillRect(0, 0, i / h, n / h), t.restore()), s) {
            var d = this.domBack;
            t.save(), t.globalAlpha = l, t.drawImage(d, 0, 0, i / h, n / h), t.restore()
        }
    }, a.merge(s.prototype, n.prototype), s
}), define("zrender/shape/Text", ["require", "../tool/area", "./Base", "../tool/util"], function(e) {
    var t = e("../tool/area"), i = e("./Base"), n = function(e) {
        i.call(this, e)
    };
    return n.prototype = {type: "text",brush: function(e, i) {
            var n = this.style;
            if (i && (n = this.getHighlightStyle(n, this.highlightStyle || {})), "undefined" != typeof n.text && n.text !== !1) {
                e.save(), this.doClip(e), this.setContext(e, n), this.setTransform(e), n.textFont && (e.font = n.textFont), e.textAlign = n.textAlign || "start", e.textBaseline = n.textBaseline || "middle";
                var a, o = (n.text + "").split("\n"), r = t.getTextHeight("国", n.textFont), s = this.getRect(n), l = n.x;
                a = "top" == n.textBaseline ? s.y : "bottom" == n.textBaseline ? s.y + r : s.y + r / 2;
                for (var h = 0, d = o.length; d > h; h++) {
                    if (n.maxWidth)
                        switch (n.brushType) {
                            case "fill":
                                e.fillText(o[h], l, a, n.maxWidth);
                                break;
                            case "stroke":
                                e.strokeText(o[h], l, a, n.maxWidth);
                                break;
                            case "both":
                                e.fillText(o[h], l, a, n.maxWidth), e.strokeText(o[h], l, a, n.maxWidth);
                                break;
                            default:
                                e.fillText(o[h], l, a, n.maxWidth)
                        }
                    else
                        switch (n.brushType) {
                            case "fill":
                                e.fillText(o[h], l, a);
                                break;
                            case "stroke":
                                e.strokeText(o[h], l, a);
                                break;
                            case "both":
                                e.fillText(o[h], l, a), e.strokeText(o[h], l, a);
                                break;
                            default:
                                e.fillText(o[h], l, a)
                        }
                    a += r
                }
                e.restore()
            }
        },getRect: function(e) {
            if (e.__rect)
                return e.__rect;
            var i = t.getTextWidth(e.text, e.textFont), n = t.getTextHeight(e.text, e.textFont), a = e.x;
            "end" == e.textAlign || "right" == e.textAlign ? a -= i : "center" == e.textAlign && (a -= i / 2);
            var o;
            return o = "top" == e.textBaseline ? e.y : "bottom" == e.textBaseline ? e.y - n : e.y - n / 2, e.__rect = {x: a,y: o,width: i,height: n}, e.__rect
        }}, e("../tool/util").inherits(n, i), n
}), define("zrender/shape/Rectangle", ["require", "./Base", "../tool/util"], function(e) {
    var t = e("./Base"), i = function(e) {
        t.call(this, e)
    };
    return i.prototype = {type: "rectangle",_buildRadiusPath: function(e, t) {
            var i, n, a, o, r = t.x, s = t.y, l = t.width, h = t.height, d = t.radius;
            "number" == typeof d ? i = n = a = o = d : d instanceof Array ? 1 === d.length ? i = n = a = o = d[0] : 2 === d.length ? (i = a = d[0], n = o = d[1]) : 3 === d.length ? (i = d[0], n = o = d[1], a = d[2]) : (i = d[0], n = d[1], a = d[2], o = d[3]) : i = n = a = o = 0;
            var c;
            i + n > l && (c = i + n, i *= l / c, n *= l / c), a + o > l && (c = a + o, a *= l / c, o *= l / c), n + a > h && (c = n + a, n *= h / c, a *= h / c), i + o > h && (c = i + o, i *= h / c, o *= h / c), e.moveTo(r + i, s), e.lineTo(r + l - n, s), 0 !== n && e.quadraticCurveTo(r + l, s, r + l, s + n), e.lineTo(r + l, s + h - a), 0 !== a && e.quadraticCurveTo(r + l, s + h, r + l - a, s + h), e.lineTo(r + o, s + h), 0 !== o && e.quadraticCurveTo(r, s + h, r, s + h - o), e.lineTo(r, s + i), 0 !== i && e.quadraticCurveTo(r, s, r + i, s)
        },buildPath: function(e, t) {
            t.radius ? this._buildRadiusPath(e, t) : (e.moveTo(t.x, t.y), e.lineTo(t.x + t.width, t.y), e.lineTo(t.x + t.width, t.y + t.height), e.lineTo(t.x, t.y + t.height), e.lineTo(t.x, t.y)), e.closePath()
        },getRect: function(e) {
            if (e.__rect)
                return e.__rect;
            var t;
            return t = "stroke" == e.brushType || "fill" == e.brushType ? e.lineWidth || 1 : 0, e.__rect = {x: Math.round(e.x - t / 2),y: Math.round(e.y - t / 2),width: e.width + t,height: e.height + t}, e.__rect
        }}, e("../tool/util").inherits(i, t), i
}), define("zrender/tool/area", ["require", "./util", "./curve"], function(e) {
    "use strict";
    function t(e) {
        return e %= C, 0 > e && (e += C), e
    }
    function i(e, t, i, o) {
        if (!t || !e)
            return !1;
        var r = e.type;
        v = v || L.getContext();
        var s = n(e, t, i, o);
        if ("undefined" != typeof s)
            return s;
        if (e.buildPath && v.isPointInPath)
            return a(e, v, t, i, o);
        switch (r) {
            case "ellipse":
                return !0;
            case "trochoid":
                var l = "out" == t.location ? t.r1 + t.r2 + t.d : t.r1 - t.r2 + t.d;
                return p(t, i, o, l);
            case "rose":
                return p(t, i, o, t.maxr);
            default:
                return !1
        }
    }
    function n(e, t, i, n) {
        var a = e.type;
        switch (a) {
            case "bezier-curve":
                return "undefined" == typeof t.cpX2 ? l(t.xStart, t.yStart, t.cpX1, t.cpY1, t.xEnd, t.yEnd, t.lineWidth, i, n) : s(t.xStart, t.yStart, t.cpX1, t.cpY1, t.cpX2, t.cpY2, t.xEnd, t.yEnd, t.lineWidth, i, n);
            case "line":
                return r(t.xStart, t.yStart, t.xEnd, t.yEnd, t.lineWidth, i, n);
            case "polyline":
                return d(t.pointList, t.lineWidth, i, n);
            case "ring":
                return c(t.x, t.y, t.r0, t.r, i, n);
            case "circle":
                return p(t.x, t.y, t.r, i, n);
            case "sector":
                var o = t.startAngle * Math.PI / 180, h = t.endAngle * Math.PI / 180;
                return t.clockWise || (o = -o, h = -h), u(t.x, t.y, t.r0, t.r, o, h, !t.clockWise, i, n);
            case "path":
                return t.pathArray && _(t.pathArray, Math.max(t.lineWidth, 5), t.brushType, i, n);
            case "polygon":
            case "star":
            case "isogon":
                return V(t.pointList, i, n);
            case "text":
                var U = t.__rect || e.getRect(t);
                return m(U.x, U.y, U.width, U.height, i, n);
            case "rectangle":
            case "image":
                return m(t.x, t.y, t.width, t.height, i, n)
        }
    }
    function a(e, t, i, n, a) {
        return t.beginPath(), e.buildPath(t, i), t.closePath(), t.isPointInPath(n, a)
    }
    function o(e, t, n, a) {
        return !i(e, t, n, a)
    }
    function r(e, t, i, n, a, o, r) {
        if (0 === a)
            return !1;
        var s = Math.max(a, 5), l = 0, h = e;
        if (r > t + s && r > n + s || t - s > r && n - s > r || o > e + s && o > i + s || e - s > o && i - s > o)
            return !1;
        if (e === i)
            return Math.abs(o - e) <= s / 2;
        l = (t - n) / (e - i), h = (e * n - i * t) / (e - i);
        var d = l * o - r + h, c = d * d / (l * l + 1);
        return s / 2 * s / 2 >= c
    }
    function s(e, t, i, n, a, o, r, s, l, h, d) {
        if (0 === l)
            return !1;
        var c = Math.max(l, 5);
        if (d > t + c && d > n + c && d > o + c && d > s + c || t - c > d && n - c > d && o - c > d && s - c > d || h > e + c && h > i + c && h > a + c && h > r + c || e - c > h && i - c > h && a - c > h && r - c > h)
            return !1;
        var m = w.cubicProjectPoint(e, t, i, n, a, o, r, s, h, d, null);
        return c / 2 >= m
    }
    function l(e, t, i, n, a, o, r, s, l) {
        if (0 === r)
            return !1;
        var h = Math.max(r, 5);
        if (l > t + h && l > n + h && l > o + h || t - h > l && n - h > l && o - h > l || s > e + h && s > i + h && s > a + h || e - h > s && i - h > s && a - h > s)
            return !1;
        var d = w.quadraticProjectPoint(e, t, i, n, a, o, s, l, null);
        return h / 2 >= d
    }
    function h(e, i, n, a, o, r, s, l, h) {
        if (0 === s)
            return !1;
        var d = Math.max(s, 5);
        l -= e, h -= i;
        var c = Math.sqrt(l * l + h * h);
        if (c - d > n || n > c + d)
            return !1;
        if (Math.abs(a - o) >= C)
            return !0;
        if (r) {
            var m = a;
            a = t(o), o = t(m)
        } else
            a = t(a), o = t(o);
        a > o && (o += C);
        var p = Math.atan2(h, l);
        return 0 > p && (p += C), p >= a && o >= p || p + C >= a && o >= p + C
    }
    function d(e, t, i, n) {
        for (var t = Math.max(t, 10), a = 0, o = e.length - 1; o > a; a++) {
            var s = e[a][0], l = e[a][1], h = e[a + 1][0], d = e[a + 1][1];
            if (r(s, l, h, d, t, i, n))
                return !0
        }
        return !1
    }
    function c(e, t, i, n, a, o) {
        var r = (a - e) * (a - e) + (o - t) * (o - t);
        return n * n > r && r > i * i
    }
    function m(e, t, i, n, a, o) {
        return a >= e && e + i >= a && o >= t && t + n >= o
    }
    function p(e, t, i, n, a) {
        return i * i > (n - e) * (n - e) + (a - t) * (a - t)
    }
    function u(e, t, i, n, a, o, r, s, l) {
        return h(e, t, (i + n) / 2, a, o, r, n - i, s, l)
    }
    function V(e, t, i) {
        for (var n = e.length, a = 0, o = 0, r = n - 1; n > o; o++) {
            var s = e[r][0], l = e[r][1], h = e[o][0], d = e[o][1];
            a += U(s, l, h, d, t, i), r = o
        }
        return 0 !== a
    }
    function U(e, t, i, n, a, o) {
        if (o > t && o > n || t > o && n > o)
            return 0;
        if (n == t)
            return 0;
        var r = t > n ? 1 : -1, s = (o - t) / (n - t), l = s * (i - e) + e;
        return l > a ? r : 0
    }
    function g() {
        var e = E[0];
        E[0] = E[1], E[1] = e
    }
    function f(e, t, i, n, a, o, r, s, l, h) {
        if (h > t && h > n && h > o && h > s || t > h && n > h && o > h && s > h)
            return 0;
        var d = w.cubicRootAt(t, n, o, s, h, T);
        if (0 === d)
            return 0;
        for (var c, m, p = 0, u = -1, V = 0; d > V; V++) {
            var U = T[V], f = w.cubicAt(e, i, a, r, U);
            l > f || (0 > u && (u = w.cubicExtrema(t, n, o, s, E), E[1] < E[0] && u > 1 && g(), c = w.cubicAt(t, n, o, s, E[0]), u > 1 && (m = w.cubicAt(t, n, o, s, E[1]))), p += 2 == u ? U < E[0] ? t > c ? 1 : -1 : U < E[1] ? c > m ? 1 : -1 : m > s ? 1 : -1 : U < E[0] ? t > c ? 1 : -1 : c > s ? 1 : -1)
        }
        return p
    }
    function y(e, t, i, n, a, o, r, s) {
        if (s > t && s > n && s > o || t > s && n > s && o > s)
            return 0;
        var l = w.quadraticRootAt(t, n, o, s, T);
        if (0 === l)
            return 0;
        var h = w.quadraticExtremum(t, n, o);
        if (h >= 0 && 1 >= h) {
            for (var d = 0, c = w.quadraticAt(t, n, o, h), m = 0; l > m; m++) {
                var p = w.quadraticAt(e, i, a, T[m]);
                r > p || (d += T[m] < h ? t > c ? 1 : -1 : c > o ? 1 : -1)
            }
            return d
        }
        var p = w.quadraticAt(e, i, a, T[0]);
        return r > p ? 0 : t > o ? 1 : -1
    }
    function b(e, i, n, a, o, r, s, l) {
        if (l -= i, l > n || -n > l)
            return 0;
        var h = Math.sqrt(n * n - l * l);
        if (T[0] = -h, T[1] = h, Math.abs(a - o) >= C) {
            a = 0, o = C;
            var d = r ? 1 : -1;
            return s >= T[0] + e && s <= T[1] + e ? d : 0
        }
        if (r) {
            var h = a;
            a = t(o), o = t(h)
        } else
            a = t(a), o = t(o);
        a > o && (o += C);
        for (var c = 0, m = 0; 2 > m; m++) {
            var p = T[m];
            if (p + e > s) {
                var u = Math.atan2(l, p), d = r ? 1 : -1;
                0 > u && (u = C + u), (u >= a && o >= u || u + C >= a && o >= u + C) && (u > Math.PI / 2 && u < 1.5 * Math.PI && (d = -d), c += d)
            }
        }
        return c
    }
    function _(e, t, i, n, a) {
        var o = 0, d = 0, c = 0, m = 0, p = 0, u = !0, V = !0;
        i = i || "fill";
        for (var g = "stroke" === i || "both" === i, _ = "fill" === i || "both" === i, x = 0; x < e.length; x++) {
            var k = e[x], v = k.points;
            if (u || "M" === k.command) {
                if (x > 0 && (_ && (o += U(d, c, m, p, n, a)), 0 !== o))
                    return !0;
                m = v[v.length - 2], p = v[v.length - 1], u = !1, V && "A" !== k.command && (V = !1, d = m, c = p)
            }
            switch (k.command) {
                case "M":
                    d = v[0], c = v[1];
                    break;
                case "L":
                    if (g && r(d, c, v[0], v[1], t, n, a))
                        return !0;
                    _ && (o += U(d, c, v[0], v[1], n, a)), d = v[0], c = v[1];
                    break;
                case "C":
                    if (g && s(d, c, v[0], v[1], v[2], v[3], v[4], v[5], t, n, a))
                        return !0;
                    _ && (o += f(d, c, v[0], v[1], v[2], v[3], v[4], v[5], n, a)), d = v[4], c = v[5];
                    break;
                case "Q":
                    if (g && l(d, c, v[0], v[1], v[2], v[3], t, n, a))
                        return !0;
                    _ && (o += y(d, c, v[0], v[1], v[2], v[3], n, a)), d = v[2], c = v[3];
                    break;
                case "A":
                    var L = v[0], w = v[1], W = v[2], X = v[3], I = v[4], S = v[5], K = Math.cos(I) * W + L, C = Math.sin(I) * X + w;
                    V ? (V = !1, m = K, p = C) : o += U(d, c, K, C);
                    var T = (n - L) * X / W + L;
                    if (g && h(L, w, X, I, I + S, 1 - v[7], t, T, a))
                        return !0;
                    _ && (o += b(L, w, X, I, I + S, 1 - v[7], T, a)), d = Math.cos(I + S) * W + L, c = Math.sin(I + S) * X + w;
                    break;
                case "z":
                    if (g && r(d, c, m, p, t, n, a))
                        return !0;
                    u = !0
            }
        }
        return _ && (o += U(d, c, m, p, n, a)), 0 !== o
    }
    function x(e, t) {
        var i = e + ":" + t;
        if (W[i])
            return W[i];
        v = v || L.getContext(), v.save(), t && (v.font = t), e = (e + "").split("\n");
        for (var n = 0, a = 0, o = e.length; o > a; a++)
            n = Math.max(v.measureText(e[a]).width, n);
        return v.restore(), W[i] = n, ++I > K && (I = 0, W = {}), n
    }
    function k(e, t) {
        var i = e + ":" + t;
        if (X[i])
            return X[i];
        v = v || L.getContext(), v.save(), t && (v.font = t), e = (e + "").split("\n");
        var n = (v.measureText("国").width + 2) * e.length;
        return v.restore(), X[i] = n, ++S > K && (S = 0, X = {}), n
    }
    var v, L = e("./util"), w = e("./curve"), W = {}, X = {}, I = 0, S = 0, K = 5e3, C = 2 * Math.PI, T = [-1, -1, -1], E = [-1, -1];
    return {isInside: i,isOutside: o,getTextWidth: x,getTextHeight: k,isInsidePath: _,isInsidePolygon: V,isInsideSector: u,isInsideCircle: p,isInsideLine: r,isInsideRect: m,isInsidePolyline: d,isInsideCubicStroke: s,isInsideQuadraticStroke: l}
}), define("zrender/shape/Base", ["require", "../tool/matrix", "../tool/guid", "../tool/util", "../tool/log", "../mixin/Transformable", "../mixin/Eventful", "../tool/area", "../tool/color"], function(e) {
    function t(t, n, a, o, r, s, l) {
        r && (t.font = r), t.textAlign = s, t.textBaseline = l;
        var h = i(n, a, o, r, s, l);
        n = (n + "").split("\n");
        var d = e("../tool/area").getTextHeight("国", r);
        switch (l) {
            case "top":
                o = h.y;
                break;
            case "bottom":
                o = h.y + d;
                break;
            default:
                o = h.y + d / 2
        }
        for (var c = 0, m = n.length; m > c; c++)
            t.fillText(n[c], a, o), o += d
    }
    function i(t, i, n, a, o, r) {
        var s = e("../tool/area"), l = s.getTextWidth(t, a), h = s.getTextHeight("国", a);
        switch (t = (t + "").split("\n"), o) {
            case "end":
            case "right":
                i -= l;
                break;
            case "center":
                i -= l / 2
        }
        switch (r) {
            case "top":
                break;
            case "bottom":
                n -= h * t.length;
                break;
            default:
                n -= h * t.length / 2
        }
        return {x: i,y: n,width: l,height: h * t.length}
    }
    var n = window.G_vmlCanvasManager, a = e("../tool/matrix"), o = e("../tool/guid"), r = e("../tool/util"), s = e("../tool/log"), l = e("../mixin/Transformable"), h = e("../mixin/Eventful"), d = function(e) {
        e = e || {}, this.id = e.id || o();
        for (var t in e)
            this[t] = e[t];
        this.style = this.style || {}, this.highlightStyle = this.highlightStyle || null, this.parent = null, this.__dirty = !0, this.__clipShapes = [], l.call(this), h.call(this)
    };
    d.prototype.invisible = !1, d.prototype.ignore = !1, d.prototype.zlevel = 0, d.prototype.draggable = !1, d.prototype.clickable = !1, d.prototype.hoverable = !0, d.prototype.z = 0, d.prototype.brush = function(e, t) {
        var i = this.beforeBrush(e, t);
        switch (e.beginPath(), this.buildPath(e, i), i.brushType) {
            case "both":
                e.fill();
            case "stroke":
                i.lineWidth > 0 && e.stroke();
                break;
            default:
                e.fill()
        }
        this.drawText(e, i, this.style), this.afterBrush(e)
    }, d.prototype.beforeBrush = function(e, t) {
        var i = this.style;
        return this.brushTypeOnly && (i.brushType = this.brushTypeOnly), t && (i = this.getHighlightStyle(i, this.highlightStyle || {}, this.brushTypeOnly)), "stroke" == this.brushTypeOnly && (i.strokeColor = i.strokeColor || i.color), e.save(), this.doClip(e), this.setContext(e, i), this.setTransform(e), i
    }, d.prototype.afterBrush = function(e) {
        e.restore()
    };
    var c = [["color", "fillStyle"], ["strokeColor", "strokeStyle"], ["opacity", "globalAlpha"], ["lineCap", "lineCap"], ["lineJoin", "lineJoin"], ["miterLimit", "miterLimit"], ["lineWidth", "lineWidth"], ["shadowBlur", "shadowBlur"], ["shadowColor", "shadowColor"], ["shadowOffsetX", "shadowOffsetX"], ["shadowOffsetY", "shadowOffsetY"]];
    d.prototype.setContext = function(e, t) {
        for (var i = 0, n = c.length; n > i; i++) {
            var a = c[i][0], o = t[a], r = c[i][1];
            "undefined" != typeof o && (e[r] = o)
        }
    };
    var m = a.create();
    return d.prototype.doClip = function(e) {
        if (this.__clipShapes && !n)
            for (var t = 0; t < this.__clipShapes.length; t++) {
                var i = this.__clipShapes[t];
                if (i.needTransform) {
                    var o = i.transform;
                    a.invert(m, o), e.transform(o[0], o[1], o[2], o[3], o[4], o[5])
                }
                if (e.beginPath(), i.buildPath(e, i.style), e.clip(), i.needTransform) {
                    var o = m;
                    e.transform(o[0], o[1], o[2], o[3], o[4], o[5])
                }
            }
    }, d.prototype.getHighlightStyle = function(t, i, n) {
        var a = {};
        for (var o in t)
            a[o] = t[o];
        var r = e("../tool/color"), s = r.getHighlightColor();
        "stroke" != t.brushType ? (a.strokeColor = s, a.lineWidth = (t.lineWidth || 1) + this.getHighlightZoom(), a.brushType = "both") : "stroke" != n ? (a.strokeColor = s, a.lineWidth = (t.lineWidth || 1) + this.getHighlightZoom()) : a.strokeColor = i.strokeColor || r.mix(t.strokeColor, r.toRGB(s));
        for (var o in i)
            "undefined" != typeof i[o] && (a[o] = i[o]);
        return a
    }, d.prototype.getHighlightZoom = function() {
        return "text" != this.type ? 6 : 2
    }, d.prototype.drift = function(e, t) {
        this.position[0] += e, this.position[1] += t
    }, d.prototype.buildPath = function() {
        s("buildPath not implemented in " + this.type)
    }, d.prototype.getRect = function() {
        s("getRect not implemented in " + this.type)
    }, d.prototype.isCover = function(t, i) {
        var n = this.transformCoordToLocal(t, i);
        return t = n[0], i = n[1], this.isCoverRect(t, i) ? e("../tool/area").isInside(this, this.style, t, i) : !1
    }, d.prototype.isCoverRect = function(e, t) {
        var i = this.style.__rect;
        return i || (i = this.style.__rect = this.getRect(this.style)), e >= i.x && e <= i.x + i.width && t >= i.y && t <= i.y + i.height
    }, d.prototype.drawText = function(e, i, n) {
        if ("undefined" != typeof i.text && i.text !== !1) {
            var a = i.textColor || i.color || i.strokeColor;
            e.fillStyle = a;
            var o, r, s, l, h = 10, d = i.textPosition || this.textPosition || "top";
            switch (d) {
                case "inside":
                case "top":
                case "bottom":
                case "left":
                case "right":
                    if (this.getRect) {
                        var c = (n || i).__rect || this.getRect(n || i);
                        switch (d) {
                            case "inside":
                                s = c.x + c.width / 2, l = c.y + c.height / 2, o = "center", r = "middle", "stroke" != i.brushType && a == i.color && (e.fillStyle = "#fff");
                                break;
                            case "left":
                                s = c.x - h, l = c.y + c.height / 2, o = "end", r = "middle";
                                break;
                            case "right":
                                s = c.x + c.width + h, l = c.y + c.height / 2, o = "start", r = "middle";
                                break;
                            case "top":
                                s = c.x + c.width / 2, l = c.y - h, o = "center", r = "bottom";
                                break;
                            case "bottom":
                                s = c.x + c.width / 2, l = c.y + c.height + h, o = "center", r = "top"
                        }
                    }
                    break;
                case "start":
                case "end":
                    var m = i.pointList || [[i.xStart || 0, i.yStart || 0], [i.xEnd || 0, i.yEnd || 0]], p = m.length;
                    if (2 > p)
                        return;
                    var u, V, U, g;
                    switch (d) {
                        case "start":
                            u = m[1][0], V = m[0][0], U = m[1][1], g = m[0][1];
                            break;
                        case "end":
                            u = m[p - 2][0], V = m[p - 1][0], U = m[p - 2][1], g = m[p - 1][1]
                    }
                    s = V, l = g;
                    var f = Math.atan((U - g) / (V - u)) / Math.PI * 180;
                    0 > V - u ? f += 180 : 0 > U - g && (f += 360), h = 5, f >= 30 && 150 >= f ? (o = "center", r = "bottom", l -= h) : f > 150 && 210 > f ? (o = "right", r = "middle", s -= h) : f >= 210 && 330 >= f ? (o = "center", r = "top", l += h) : (o = "left", r = "middle", s += h);
                    break;
                case "specific":
                    s = i.textX || 0, l = i.textY || 0, o = "start", r = "middle"
            }
            null != s && null != l && t(e, i.text, s, l, i.textFont, i.textAlign || o, i.textBaseline || r)
        }
    }, d.prototype.modSelf = function() {
        this.__dirty = !0, this.style && (this.style.__rect = null), this.highlightStyle && (this.highlightStyle.__rect = null)
    }, d.prototype.isSilent = function() {
        return !(this.hoverable || this.draggable || this.clickable || this.onmousemove || this.onmouseover || this.onmouseout || this.onmousedown || this.onmouseup || this.onclick || this.ondragenter || this.ondragover || this.ondragleave || this.ondrop)
    }, r.merge(d.prototype, l.prototype, !0), r.merge(d.prototype, h.prototype, !0), d
}), define("zrender/tool/curve", ["require", "./vector"], function(e) {
    function t(e) {
        return e > -U && U > e
    }
    function i(e) {
        return e > U || -U > e
    }
    function n(e, t, i, n, a) {
        var o = 1 - a;
        return o * o * (o * e + 3 * a * t) + a * a * (a * n + 3 * o * i)
    }
    function a(e, t, i, n, a) {
        var o = 1 - a;
        return 3 * (((t - e) * o + 2 * (i - t) * a) * o + (n - i) * a * a)
    }
    function o(e, i, n, a, o, r) {
        var s = a + 3 * (i - n) - e, l = 3 * (n - 2 * i + e), h = 3 * (i - e), d = e - o, c = l * l - 3 * s * h, m = l * h - 9 * s * d, p = h * h - 3 * l * d, u = 0;
        if (t(c) && t(m))
            if (t(l))
                r[0] = 0;
            else {
                var V = -h / l;
                V >= 0 && 1 >= V && (r[u++] = V)
            }
        else {
            var U = m * m - 4 * c * p;
            if (t(U)) {
                var y = m / c, V = -l / s + y, b = -y / 2;
                V >= 0 && 1 >= V && (r[u++] = V), b >= 0 && 1 >= b && (r[u++] = b)
            } else if (U > 0) {
                var _ = Math.sqrt(U), x = c * l + 1.5 * s * (-m + _), k = c * l + 1.5 * s * (-m - _);
                x = 0 > x ? -Math.pow(-x, f) : Math.pow(x, f), k = 0 > k ? -Math.pow(-k, f) : Math.pow(k, f);
                var V = (-l - (x + k)) / (3 * s);
                V >= 0 && 1 >= V && (r[u++] = V)
            } else {
                var v = (2 * c * l - 3 * s * m) / (2 * Math.sqrt(c * c * c)), L = Math.acos(v) / 3, w = Math.sqrt(c), W = Math.cos(L), V = (-l - 2 * w * W) / (3 * s), b = (-l + w * (W + g * Math.sin(L))) / (3 * s), X = (-l + w * (W - g * Math.sin(L))) / (3 * s);
                V >= 0 && 1 >= V && (r[u++] = V), b >= 0 && 1 >= b && (r[u++] = b), X >= 0 && 1 >= X && (r[u++] = X)
            }
        }
        return u
    }
    function r(e, n, a, o, r) {
        var s = 6 * a - 12 * n + 6 * e, l = 9 * n + 3 * o - 3 * e - 9 * a, h = 3 * n - 3 * e, d = 0;
        if (t(l)) {
            if (i(s)) {
                var c = -h / s;
                c >= 0 && 1 >= c && (r[d++] = c)
            }
        } else {
            var m = s * s - 4 * l * h;
            if (t(m))
                r[0] = -s / (2 * l);
            else if (m > 0) {
                var p = Math.sqrt(m), c = (-s + p) / (2 * l), u = (-s - p) / (2 * l);
                c >= 0 && 1 >= c && (r[d++] = c), u >= 0 && 1 >= u && (r[d++] = u)
            }
        }
        return d
    }
    function s(e, t, i, n, a, o) {
        var r = (t - e) * a + e, s = (i - t) * a + t, l = (n - i) * a + i, h = (s - r) * a + r, d = (l - s) * a + s, c = (d - h) * a + h;
        o[0] = e, o[1] = r, o[2] = h, o[3] = c, o[4] = c, o[5] = d, o[6] = l, o[7] = n
    }
    function l(e, t, i, a, o, r, s, l, h, d, c) {
        var m, p = .005, u = 1 / 0;
        y[0] = h, y[1] = d;
        for (var g = 0; 1 > g; g += .05) {
            b[0] = n(e, i, o, s, g), b[1] = n(t, a, r, l, g);
            var f = V.distSquare(y, b);
            u > f && (m = g, u = f)
        }
        u = 1 / 0;
        for (var x = 0; 32 > x && !(U > p); x++) {
            var k = m - p, v = m + p;
            b[0] = n(e, i, o, s, k), b[1] = n(t, a, r, l, k);
            var f = V.distSquare(b, y);
            if (k >= 0 && u > f)
                m = k, u = f;
            else {
                _[0] = n(e, i, o, s, v), _[1] = n(t, a, r, l, v);
                var L = V.distSquare(_, y);
                1 >= v && u > L ? (m = v, u = L) : p *= .5
            }
        }
        return c && (c[0] = n(e, i, o, s, m), c[1] = n(t, a, r, l, m)), Math.sqrt(u)
    }
    function h(e, t, i, n) {
        var a = 1 - n;
        return a * (a * e + 2 * n * t) + n * n * i
    }
    function d(e, t, i, n) {
        return 2 * ((1 - n) * (t - e) + n * (i - t))
    }
    function c(e, n, a, o, r) {
        var s = e - 2 * n + a, l = 2 * (n - e), h = e - o, d = 0;
        if (t(s)) {
            if (i(l)) {
                var c = -h / l;
                c >= 0 && 1 >= c && (r[d++] = c)
            }
        } else {
            var m = l * l - 4 * s * h;
            if (t(m)) {
                var c = -l / (2 * s);
                c >= 0 && 1 >= c && (r[d++] = c)
            } else if (m > 0) {
                var p = Math.sqrt(m), c = (-l + p) / (2 * s), u = (-l - p) / (2 * s);
                c >= 0 && 1 >= c && (r[d++] = c), u >= 0 && 1 >= u && (r[d++] = u)
            }
        }
        return d
    }
    function m(e, t, i) {
        var n = e + i - 2 * t;
        return 0 === n ? .5 : (e - t) / n
    }
    function p(e, t, i, n, a) {
        var o = (t - e) * n + e, r = (i - t) * n + t, s = (r - o) * n + o;
        a[0] = e, a[1] = o, a[2] = s, a[3] = s, a[4] = r, a[5] = i
    }
    function u(e, t, i, n, a, o, r, s, l) {
        var d, c = .005, m = 1 / 0;
        y[0] = r, y[1] = s;
        for (var p = 0; 1 > p; p += .05) {
            b[0] = h(e, i, a, p), b[1] = h(t, n, o, p);
            var u = V.distSquare(y, b);
            m > u && (d = p, m = u)
        }
        m = 1 / 0;
        for (var g = 0; 32 > g && !(U > c); g++) {
            var f = d - c, x = d + c;
            b[0] = h(e, i, a, f), b[1] = h(t, n, o, f);
            var u = V.distSquare(b, y);
            if (f >= 0 && m > u)
                d = f, m = u;
            else {
                _[0] = h(e, i, a, x), _[1] = h(t, n, o, x);
                var k = V.distSquare(_, y);
                1 >= x && m > k ? (d = x, m = k) : c *= .5
            }
        }
        return l && (l[0] = h(e, i, a, d), l[1] = h(t, n, o, d)), Math.sqrt(m)
    }
    var V = e("./vector"), U = 1e-4, g = Math.sqrt(3), f = 1 / 3, y = V.create(), b = V.create(), _ = V.create();
    return {cubicAt: n,cubicDerivativeAt: a,cubicRootAt: o,cubicExtrema: r,cubicSubdivide: s,cubicProjectPoint: l,quadraticAt: h,quadraticDerivativeAt: d,quadraticRootAt: c,quadraticExtremum: m,quadraticSubdivide: p,quadraticProjectPoint: u}
}), define("zrender/mixin/Transformable", ["require", "../tool/matrix", "../tool/vector"], function(e) {
    "use strict";
    function t(e) {
        return e > -s && s > e
    }
    function i(e) {
        return e > s || -s > e
    }
    var n = e("../tool/matrix"), a = e("../tool/vector"), o = [0, 0], r = n.translate, s = 5e-5, l = function() {
        this.position || (this.position = [0, 0]), "undefined" == typeof this.rotation && (this.rotation = [0, 0, 0]), this.scale || (this.scale = [1, 1, 0, 0]), this.needLocalTransform = !1, this.needTransform = !1
    };
    return l.prototype = {constructor: l,updateNeedTransform: function() {
            this.needLocalTransform = i(this.rotation[0]) || i(this.position[0]) || i(this.position[1]) || i(this.scale[0] - 1) || i(this.scale[1] - 1)
        },updateTransform: function() {
            this.updateNeedTransform();
            var e = this.parent && this.parent.needTransform;
            if (this.needTransform = this.needLocalTransform || e, this.needTransform) {
                var t = this.transform || n.create();
                if (n.identity(t), this.needLocalTransform) {
                    var a = this.scale;
                    if (i(a[0]) || i(a[1])) {
                        o[0] = -a[2] || 0, o[1] = -a[3] || 0;
                        var s = i(o[0]) || i(o[1]);
                        s && r(t, t, o), n.scale(t, t, a), s && (o[0] = -o[0], o[1] = -o[1], r(t, t, o))
                    }
                    if (this.rotation instanceof Array) {
                        if (0 !== this.rotation[0]) {
                            o[0] = -this.rotation[1] || 0, o[1] = -this.rotation[2] || 0;
                            var s = i(o[0]) || i(o[1]);
                            s && r(t, t, o), n.rotate(t, t, this.rotation[0]), s && (o[0] = -o[0], o[1] = -o[1], r(t, t, o))
                        }
                    } else
                        0 !== this.rotation && n.rotate(t, t, this.rotation);
                    (i(this.position[0]) || i(this.position[1])) && r(t, t, this.position)
                }
                e && (this.needLocalTransform ? n.mul(t, this.parent.transform, t) : n.copy(t, this.parent.transform)), this.transform = t, this.invTransform = this.invTransform || n.create(), n.invert(this.invTransform, t)
            }
        },setTransform: function(e) {
            if (this.needTransform) {
                var t = this.transform;
                e.transform(t[0], t[1], t[2], t[3], t[4], t[5])
            }
        },lookAt: function() {
            var e = a.create();
            return function(i) {
                this.transform || (this.transform = n.create());
                var o = this.transform;
                if (a.sub(e, i, this.position), !t(e[0]) || !t(e[1])) {
                    a.normalize(e, e);
                    var r = this.scale;
                    o[2] = e[0] * r[1], o[3] = e[1] * r[1], o[0] = e[1] * r[0], o[1] = -e[0] * r[0], o[4] = this.position[0], o[5] = this.position[1], this.decomposeTransform()
                }
            }
        }(),decomposeTransform: function() {
            if (this.transform) {
                var e = this.transform, t = e[0] * e[0] + e[1] * e[1], n = this.position, a = this.scale, o = this.rotation;
                i(t - 1) && (t = Math.sqrt(t));
                var r = e[2] * e[2] + e[3] * e[3];
                i(r - 1) && (r = Math.sqrt(r)), n[0] = e[4], n[1] = e[5], a[0] = t, a[1] = r, a[2] = a[3] = 0, o[0] = Math.atan2(-e[1] / r, e[0] / t), o[1] = o[2] = 0
            }
        },transformCoordToLocal: function(e, t) {
            var i = [e, t];
            return this.needTransform && this.invTransform && a.applyTransform(i, i, this.invTransform), i
        }}, l
}), define("zrender/Group", ["require", "./tool/guid", "./tool/util", "./mixin/Transformable", "./mixin/Eventful"], function(e) {
    var t = e("./tool/guid"), i = e("./tool/util"), n = e("./mixin/Transformable"), a = e("./mixin/Eventful"), o = function(e) {
        e = e || {}, this.id = e.id || t();
        for (var i in e)
            this[i] = e[i];
        this.type = "group", this.clipShape = null, this._children = [], this._storage = null, this.__dirty = !0, n.call(this), a.call(this)
    };
    return o.prototype.ignore = !1, o.prototype.children = function() {
        return this._children.slice()
    }, o.prototype.childAt = function(e) {
        return this._children[e]
    }, o.prototype.addChild = function(e) {
        e != this && e.parent != this && (e.parent && e.parent.removeChild(e), this._children.push(e), e.parent = this, this._storage && this._storage !== e._storage && (this._storage.addToMap(e), e instanceof o && e.addChildrenToStorage(this._storage)))
    }, o.prototype.removeChild = function(e) {
        var t = i.indexOf(this._children, e);
        t >= 0 && this._children.splice(t, 1), e.parent = null, this._storage && (this._storage.delFromMap(e.id), e instanceof o && e.delChildrenFromStorage(this._storage))
    }, o.prototype.clearChildren = function() {
        for (var e = 0; e < this._children.length; e++) {
            var t = this._children[e];
            this._storage && (this._storage.delFromMap(t.id), t instanceof o && t.delChildrenFromStorage(this._storage))
        }
        this._children.length = 0
    }, o.prototype.eachChild = function(e, t) {
        for (var i = !!t, n = 0; n < this._children.length; n++) {
            var a = this._children[n];
            i ? e.call(t, a) : e(a)
        }
    }, o.prototype.traverse = function(e, t) {
        for (var i = !!t, n = 0; n < this._children.length; n++) {
            var a = this._children[n];
            i ? e.call(t, a) : e(a), "group" === a.type && a.traverse(e, t)
        }
    }, o.prototype.addChildrenToStorage = function(e) {
        for (var t = 0; t < this._children.length; t++) {
            var i = this._children[t];
            e.addToMap(i), i instanceof o && i.addChildrenToStorage(e)
        }
    }, o.prototype.delChildrenFromStorage = function(e) {
        for (var t = 0; t < this._children.length; t++) {
            var i = this._children[t];
            e.delFromMap(i.id), i instanceof o && i.delChildrenFromStorage(e)
        }
    }, o.prototype.modSelf = function() {
        this.__dirty = !0
    }, i.merge(o.prototype, n.prototype, !0), i.merge(o.prototype, a.prototype, !0), o
}), define("zrender/animation/Clip", ["require", "./easing"], function(e) {
    function t(e) {
        this._targetPool = e.target || {}, this._targetPool instanceof Array || (this._targetPool = [this._targetPool]), this._life = e.life || 1e3, this._delay = e.delay || 0, this._startTime = (new Date).getTime() + this._delay, this._endTime = this._startTime + 1e3 * this._life, this.loop = "undefined" == typeof e.loop ? !1 : e.loop, this.gap = e.gap || 0, this.easing = e.easing || "Linear", this.onframe = e.onframe, this.ondestroy = e.ondestroy, this.onrestart = e.onrestart
    }
    var i = e("./easing");
    return t.prototype = {step: function(e) {
            var t = (e - this._startTime) / this._life;
            if (!(0 > t)) {
                t = Math.min(t, 1);
                var n = "string" == typeof this.easing ? i[this.easing] : this.easing, a = "function" == typeof n ? n(t) : t;
                return this.fire("frame", a), 1 == t ? this.loop ? (this.restart(), "restart") : (this.__needsRemove = !0, "destroy") : null
            }
        },restart: function() {
            var e = (new Date).getTime(), t = (e - this._startTime) % this._life;
            this._startTime = (new Date).getTime() - t + this.gap, this.__needsRemove = !1
        },fire: function(e, t) {
            for (var i = 0, n = this._targetPool.length; n > i; i++)
                this["on" + e] && this["on" + e](this._targetPool[i], t)
        },constructor: t}, t
}), define("zrender/animation/easing", [], function() {
    var e = {Linear: function(e) {
            return e
        },QuadraticIn: function(e) {
            return e * e
        },QuadraticOut: function(e) {
            return e * (2 - e)
        },QuadraticInOut: function(e) {
            return (e *= 2) < 1 ? .5 * e * e : -.5 * (--e * (e - 2) - 1)
        },CubicIn: function(e) {
            return e * e * e
        },CubicOut: function(e) {
            return --e * e * e + 1
        },CubicInOut: function(e) {
            return (e *= 2) < 1 ? .5 * e * e * e : .5 * ((e -= 2) * e * e + 2)
        },QuarticIn: function(e) {
            return e * e * e * e
        },QuarticOut: function(e) {
            return 1 - --e * e * e * e
        },QuarticInOut: function(e) {
            return (e *= 2) < 1 ? .5 * e * e * e * e : -.5 * ((e -= 2) * e * e * e - 2)
        },QuinticIn: function(e) {
            return e * e * e * e * e
        },QuinticOut: function(e) {
            return --e * e * e * e * e + 1
        },QuinticInOut: function(e) {
            return (e *= 2) < 1 ? .5 * e * e * e * e * e : .5 * ((e -= 2) * e * e * e * e + 2)
        },SinusoidalIn: function(e) {
            return 1 - Math.cos(e * Math.PI / 2)
        },SinusoidalOut: function(e) {
            return Math.sin(e * Math.PI / 2)
        },SinusoidalInOut: function(e) {
            return .5 * (1 - Math.cos(Math.PI * e))
        },ExponentialIn: function(e) {
            return 0 === e ? 0 : Math.pow(1024, e - 1)
        },ExponentialOut: function(e) {
            return 1 === e ? 1 : 1 - Math.pow(2, -10 * e)
        },ExponentialInOut: function(e) {
            return 0 === e ? 0 : 1 === e ? 1 : (e *= 2) < 1 ? .5 * Math.pow(1024, e - 1) : .5 * (-Math.pow(2, -10 * (e - 1)) + 2)
        },CircularIn: function(e) {
            return 1 - Math.sqrt(1 - e * e)
        },CircularOut: function(e) {
            return Math.sqrt(1 - --e * e)
        },CircularInOut: function(e) {
            return (e *= 2) < 1 ? -.5 * (Math.sqrt(1 - e * e) - 1) : .5 * (Math.sqrt(1 - (e -= 2) * e) + 1)
        },ElasticIn: function(e) {
            var t, i = .1, n = .4;
            return 0 === e ? 0 : 1 === e ? 1 : (!i || 1 > i ? (i = 1, t = n / 4) : t = n * Math.asin(1 / i) / (2 * Math.PI), -(i * Math.pow(2, 10 * (e -= 1)) * Math.sin(2 * (e - t) * Math.PI / n)))
        },ElasticOut: function(e) {
            var t, i = .1, n = .4;
            return 0 === e ? 0 : 1 === e ? 1 : (!i || 1 > i ? (i = 1, t = n / 4) : t = n * Math.asin(1 / i) / (2 * Math.PI), i * Math.pow(2, -10 * e) * Math.sin(2 * (e - t) * Math.PI / n) + 1);
        
        },ElasticInOut: function(e) {
            var t, i = .1, n = .4;
            return 0 === e ? 0 : 1 === e ? 1 : (!i || 1 > i ? (i = 1, t = n / 4) : t = n * Math.asin(1 / i) / (2 * Math.PI), (e *= 2) < 1 ? -.5 * i * Math.pow(2, 10 * (e -= 1)) * Math.sin(2 * (e - t) * Math.PI / n) : i * Math.pow(2, -10 * (e -= 1)) * Math.sin(2 * (e - t) * Math.PI / n) * .5 + 1)
        },BackIn: function(e) {
            var t = 1.70158;
            return e * e * ((t + 1) * e - t)
        },BackOut: function(e) {
            var t = 1.70158;
            return --e * e * ((t + 1) * e + t) + 1
        },BackInOut: function(e) {
            var t = 2.5949095;
            return (e *= 2) < 1 ? .5 * e * e * ((t + 1) * e - t) : .5 * ((e -= 2) * e * ((t + 1) * e + t) + 2)
        },BounceIn: function(t) {
            return 1 - e.BounceOut(1 - t)
        },BounceOut: function(e) {
            return 1 / 2.75 > e ? 7.5625 * e * e : 2 / 2.75 > e ? 7.5625 * (e -= 1.5 / 2.75) * e + .75 : 2.5 / 2.75 > e ? 7.5625 * (e -= 2.25 / 2.75) * e + .9375 : 7.5625 * (e -= 2.625 / 2.75) * e + .984375
        },BounceInOut: function(t) {
            return .5 > t ? .5 * e.BounceIn(2 * t) : .5 * e.BounceOut(2 * t - 1) + .5
        }};
    return e
}), define("echarts/chart/base", ["require", "zrender/shape/Image", "../util/shape/Icon", "../util/shape/MarkLine", "../util/shape/Symbol", "zrender/shape/Polyline", "zrender/shape/ShapeBundle", "../config", "../util/ecData", "../util/ecAnimation", "../util/ecEffect", "../util/accMath", "../component/base", "../layout/EdgeBundling", "zrender/tool/util", "zrender/tool/area"], function(e) {
    function t(e) {
        return null != e.x && null != e.y
    }
    function i(e, t, i, n, a) {
        u.call(this, e, t, i, n, a);
        var o = this;
        this.selectedMap = {}, this.lastShapeList = [], this.shapeHandler = {onclick: function() {
                o.isClick = !0
            },ondragover: function(e) {
                var t = e.target;
                t.highlightStyle = t.highlightStyle || {};
                var i = t.highlightStyle, n = i.brushTyep, a = i.strokeColor, r = i.lineWidth;
                i.brushType = "stroke", i.strokeColor = o.ecTheme.calculableColor || h.calculableColor, i.lineWidth = "icon" === t.type ? 30 : 10, o.zr.addHoverShape(t), setTimeout(function() {
                    i && (i.brushType = n, i.strokeColor = a, i.lineWidth = r)
                }, 20)
            },ondrop: function(e) {
                null != d.get(e.dragged, "data") && (o.isDrop = !0)
            },ondragend: function() {
                o.isDragend = !0
            }}
    }
    var n = e("zrender/shape/Image"), a = e("../util/shape/Icon"), o = e("../util/shape/MarkLine"), r = e("../util/shape/Symbol"), s = e("zrender/shape/Polyline"), l = e("zrender/shape/ShapeBundle"), h = e("../config"), d = e("../util/ecData"), c = e("../util/ecAnimation"), m = e("../util/ecEffect"), p = e("../util/accMath"), u = e("../component/base"), V = e("../layout/EdgeBundling"), U = e("zrender/tool/util"), g = e("zrender/tool/area");
    return i.prototype = {setCalculable: function(e) {
            return e.dragEnableTime = this.ecTheme.DRAG_ENABLE_TIME || h.DRAG_ENABLE_TIME, e.ondragover = this.shapeHandler.ondragover, e.ondragend = this.shapeHandler.ondragend, e.ondrop = this.shapeHandler.ondrop, e
        },ondrop: function(e, t) {
            if (this.isDrop && e.target && !t.dragIn) {
                var i, n = e.target, a = e.dragged, o = d.get(n, "seriesIndex"), r = d.get(n, "dataIndex"), s = this.series, l = this.component.legend;
                if (-1 === r) {
                    if (d.get(a, "seriesIndex") == o)
                        return t.dragOut = t.dragIn = t.needRefresh = !0, void (this.isDrop = !1);
                    i = {value: d.get(a, "value"),name: d.get(a, "name")}, this.type === h.CHART_TYPE_PIE && i.value < 0 && (i.value = 0);
                    for (var c = !1, m = s[o].data, u = 0, V = m.length; V > u; u++)
                        m[u].name === i.name && "-" === m[u].value && (s[o].data[u].value = i.value, c = !0);
                    !c && s[o].data.push(i), l && l.add(i.name, a.style.color || a.style.strokeColor)
                } else
                    i = s[o].data[r] || "-", null != i.value ? (s[o].data[r].value = "-" != i.value ? p.accAdd(s[o].data[r].value, d.get(a, "value")) : d.get(a, "value"), (this.type === h.CHART_TYPE_FUNNEL || this.type === h.CHART_TYPE_PIE) && (l && 1 === l.getRelatedAmount(i.name) && this.component.legend.del(i.name), i.name += this.option.nameConnector + d.get(a, "name"), l && l.add(i.name, a.style.color || a.style.strokeColor))) : s[o].data[r] = "-" != i ? p.accAdd(s[o].data[r], d.get(a, "value")) : d.get(a, "value");
                t.dragIn = t.dragIn || !0, this.isDrop = !1;
                var U = this;
                setTimeout(function() {
                    U.zr.trigger("mousemove", e.event)
                }, 300)
            }
        },ondragend: function(e, t) {
            if (this.isDragend && e.target && !t.dragOut) {
                var i = e.target, n = d.get(i, "seriesIndex"), a = d.get(i, "dataIndex"), o = this.series;
                if (null != o[n].data[a].value) {
                    o[n].data[a].value = "-";
                    var r = o[n].data[a].name, s = this.component.legend;
                    s && 0 === s.getRelatedAmount(r) && s.del(r)
                } else
                    o[n].data[a] = "-";
                t.dragOut = !0, t.needRefresh = !0, this.isDragend = !1
            }
        },onlegendSelected: function(e, t) {
            var i = e.selected;
            for (var n in this.selectedMap)
                this.selectedMap[n] != i[n] && (t.needRefresh = !0), this.selectedMap[n] = i[n]
        },_buildPosition: function() {
            this._symbol = this.option.symbolList, this._sIndex2ShapeMap = {}, this._sIndex2ColorMap = {}, this.selectedMap = {}, this.xMarkMap = {};
            for (var e, t, i, n, a = this.series, o = {top: [],bottom: [],left: [],right: [],other: []}, r = 0, s = a.length; s > r; r++)
                a[r].type === this.type && (a[r] = this.reformOption(a[r]), this.legendHoverLink = a[r].legendHoverLink || this.legendHoverLink, e = a[r].xAxisIndex, t = a[r].yAxisIndex, i = this.component.xAxis.getAxis(e), n = this.component.yAxis.getAxis(t), i.type === h.COMPONENT_TYPE_AXIS_CATEGORY ? o[i.getPosition()].push(r) : n.type === h.COMPONENT_TYPE_AXIS_CATEGORY ? o[n.getPosition()].push(r) : o.other.push(r));
            for (var l in o)
                o[l].length > 0 && this._buildSinglePosition(l, o[l]);
            this.addShapeList()
        },_buildSinglePosition: function(e, t) {
            var i = this._mapData(t), n = i.locationMap, a = i.maxDataLength;
            if (0 !== a && 0 !== n.length) {
                switch (e) {
                    case "bottom":
                    case "top":
                        this._buildHorizontal(t, a, n, this.xMarkMap);
                        break;
                    case "left":
                    case "right":
                        this._buildVertical(t, a, n, this.xMarkMap);
                        break;
                    case "other":
                        this._buildOther(t, a, n, this.xMarkMap)
                }
                for (var o = 0, r = t.length; r > o; o++)
                    this.buildMark(t[o])
            }
        },_mapData: function(e) {
            for (var t, i, n, a, o = this.series, r = 0, s = {}, l = "__kener__stack__", d = this.component.legend, c = [], m = 0, p = 0, u = e.length; u > p; p++) {
                if (t = o[e[p]], n = t.name, this._sIndex2ShapeMap[e[p]] = this._sIndex2ShapeMap[e[p]] || this.query(t, "symbol") || this._symbol[p % this._symbol.length], d) {
                    if (this.selectedMap[n] = d.isSelected(n), this._sIndex2ColorMap[e[p]] = d.getColor(n), a = d.getItemShape(n)) {
                        var V = a.style;
                        if (this.type == h.CHART_TYPE_LINE)
                            V.iconType = "legendLineIcon", V.symbol = this._sIndex2ShapeMap[e[p]];
                        else if (t.itemStyle.normal.barBorderWidth > 0) {
                            var U = a.highlightStyle;
                            V.brushType = "both", V.x += 1, V.y += 1, V.width -= 2, V.height -= 2, V.strokeColor = U.strokeColor = t.itemStyle.normal.barBorderColor, U.lineWidth = 3
                        }
                        d.setItemShape(n, a)
                    }
                } else
                    this.selectedMap[n] = !0, this._sIndex2ColorMap[e[p]] = this.zr.getColor(e[p]);
                this.selectedMap[n] && (i = t.stack || l + e[p], null == s[i] ? (s[i] = r, c[r] = [e[p]], r++) : c[s[i]].push(e[p])), m = Math.max(m, t.data.length)
            }
            return {locationMap: c,maxDataLength: m}
        },_calculMarkMapXY: function(e, t, i) {
            for (var n = this.series, a = 0, o = t.length; o > a; a++)
                for (var r = 0, s = t[a].length; s > r; r++) {
                    var l = t[a][r], h = "xy" == i ? 0 : "", d = this.component.grid, c = e[l];
                    if ("-1" != i.indexOf("x")) {
                        c["counter" + h] > 0 && (c["average" + h] = c["sum" + h] / c["counter" + h]);
                        var m = this.component.xAxis.getAxis(n[l].xAxisIndex || 0).getCoord(c["average" + h]);
                        c["averageLine" + h] = [[m, d.getYend()], [m, d.getY()]], c["minLine" + h] = [[c["minX" + h], d.getYend()], [c["minX" + h], d.getY()]], c["maxLine" + h] = [[c["maxX" + h], d.getYend()], [c["maxX" + h], d.getY()]], c.isHorizontal = !1
                    }
                    if (h = "xy" == i ? 1 : "", "-1" != i.indexOf("y")) {
                        c["counter" + h] > 0 && (c["average" + h] = c["sum" + h] / c["counter" + h]);
                        var p = this.component.yAxis.getAxis(n[l].yAxisIndex || 0).getCoord(c["average" + h]);
                        c["averageLine" + h] = [[d.getX(), p], [d.getXend(), p]], c["minLine" + h] = [[d.getX(), c["minY" + h]], [d.getXend(), c["minY" + h]]], c["maxLine" + h] = [[d.getX(), c["maxY" + h]], [d.getXend(), c["maxY" + h]]], c.isHorizontal = !0
                    }
                }
        },addLabel: function(e, t, i, n, a) {
            var o = [i, t], r = this.deepMerge(o, "itemStyle.normal.label"), s = this.deepMerge(o, "itemStyle.emphasis.label"), l = r.textStyle || {}, h = s.textStyle || {};
            if (r.show) {
                var d = e.style;
                d.text = this._getLabelText(t, i, n, "normal"), d.textPosition = null == r.position ? "horizontal" === a ? "right" : "top" : r.position, d.textColor = l.color, d.textFont = this.getFont(l), d.textAlign = l.align, d.textBaseline = l.baseline
            }
            if (s.show) {
                var c = e.highlightStyle;
                c.text = this._getLabelText(t, i, n, "emphasis"), c.textPosition = r.show ? e.style.textPosition : null == s.position ? "horizontal" === a ? "right" : "top" : s.position, c.textColor = h.color, c.textFont = this.getFont(h), c.textAlign = h.align, c.textBaseline = h.baseline
            }
            return e
        },_getLabelText: function(e, t, i, n) {
            var a = this.deepQuery([t, e], "itemStyle." + n + ".label.formatter");
            a || "emphasis" !== n || (a = this.deepQuery([t, e], "itemStyle.normal.label.formatter"));
            var o = this.getDataFromOption(t, "-");
            return a ? "function" == typeof a ? a.call(this.myChart, {seriesName: e.name,series: e,name: i,value: o,data: t,status: n}) : "string" == typeof a ? a = a.replace("{a}", "{a0}").replace("{b}", "{b0}").replace("{c}", "{c0}").replace("{a0}", e.name).replace("{b0}", i).replace("{c0}", this.numAddCommas(o)) : void 0 : o instanceof Array ? null != o[2] ? this.numAddCommas(o[2]) : o[0] + " , " + o[1] : this.numAddCommas(o)
        },buildMark: function(e) {
            var t = this.series[e];
            this.selectedMap[t.name] && (t.markLine && this._buildMarkLine(e), t.markPoint && this._buildMarkPoint(e))
        },_buildMarkPoint: function(e) {
            for (var t, i, n = (this.markAttachStyle || {})[e], a = this.series[e], o = U.clone(a.markPoint), r = 0, s = o.data.length; s > r; r++)
                t = o.data[r], i = this.getMarkCoord(e, t), t.x = null != t.x ? t.x : i[0], t.y = null != t.y ? t.y : i[1], !t.type || "max" !== t.type && "min" !== t.type || (t.value = i[3], t.name = t.name || t.type, t.symbolSize = t.symbolSize || g.getTextWidth(i[3], this.getFont()) / 2 + 5);
            for (var l = this._markPoint(e, o), r = 0, s = l.length; s > r; r++) {
                var d = l[r];
                d.zlevel = a.zlevel, d.z = a.z + 1;
                for (var c in n)
                    d[c] = U.clone(n[c]);
                this.shapeList.push(d)
            }
            if (this.type === h.CHART_TYPE_FORCE || this.type === h.CHART_TYPE_CHORD)
                for (var r = 0, s = l.length; s > r; r++)
                    this.zr.addShape(l[r])
        },_buildMarkLine: function(e) {
            for (var t, i = (this.markAttachStyle || {})[e], n = this.series[e], a = U.clone(n.markLine), o = 0, r = a.data.length; r > o; o++) {
                var s = a.data[o];
                !s.type || "max" !== s.type && "min" !== s.type && "average" !== s.type ? t = [this.getMarkCoord(e, s[0]), this.getMarkCoord(e, s[1])] : (t = this.getMarkCoord(e, s), a.data[o] = [U.clone(s), {}], a.data[o][0].name = s.name || s.type, a.data[o][0].value = "average" !== s.type ? t[3] : +t[3].toFixed(null != a.precision ? a.precision : this.deepQuery([this.ecTheme, h], "markLine.precision")), t = t[2], s = [{}, {}]), null != t && null != t[0] && null != t[1] && (a.data[o][0].x = null != s[0].x ? s[0].x : t[0][0], a.data[o][0].y = null != s[0].y ? s[0].y : t[0][1], a.data[o][1].x = null != s[1].x ? s[1].x : t[1][0], a.data[o][1].y = null != s[1].y ? s[1].y : t[1][1])
            }
            var d = this._markLine(e, a), c = a.large;
            if (c) {
                var m = new l({style: {shapeList: d}}), p = d[0];
                if (p) {
                    U.merge(m.style, p.style), U.merge(m.highlightStyle = {}, p.highlightStyle), m.style.brushType = "stroke", m.zlevel = n.zlevel, m.z = n.z + 1, m.hoverable = !1;
                    for (var u in i)
                        m[u] = U.clone(i[u])
                }
                this.shapeList.push(m), this.zr.addShape(m), m._mark = "largeLine";
                var V = a.effect;
                V.show && (m.effect = V)
            } else {
                for (var o = 0, r = d.length; r > o; o++) {
                    var g = d[o];
                    g.zlevel = n.zlevel, g.z = n.z + 1;
                    for (var u in i)
                        g[u] = U.clone(i[u]);
                    this.shapeList.push(g)
                }
                if (this.type === h.CHART_TYPE_FORCE || this.type === h.CHART_TYPE_CHORD)
                    for (var o = 0, r = d.length; r > o; o++)
                        this.zr.addShape(d[o])
            }
        },_markPoint: function(e, t) {
            var i = this.series[e], n = this.component;
            U.merge(U.merge(t, U.clone(this.ecTheme.markPoint || {})), U.clone(h.markPoint)), t.name = i.name;
            var a, o, r, s, l, c, m, p = [], u = t.data, V = n.dataRange, g = n.legend, f = this.zr.getWidth(), y = this.zr.getHeight();
            if (t.large)
                a = this.getLargeMarkPointShape(e, t), a._mark = "largePoint", a && p.push(a);
            else
                for (var b = 0, _ = u.length; _ > b; b++)
                    null != u[b].x && null != u[b].y && (r = null != u[b].value ? u[b].value : "", g && (o = g.getColor(i.name)), V && (o = isNaN(r) ? o : V.getColor(r), s = [u[b], t], l = this.deepQuery(s, "itemStyle.normal.color") || o, c = this.deepQuery(s, "itemStyle.emphasis.color") || l, null == l && null == c) || (o = null == o ? this.zr.getColor(e) : o, u[b].tooltip = u[b].tooltip || t.tooltip || {trigger: "item"}, u[b].name = null != u[b].name ? u[b].name : "", u[b].value = r, a = this.getSymbolShape(t, e, u[b], b, u[b].name, this.parsePercent(u[b].x, f), this.parsePercent(u[b].y, y), "pin", o, "rgba(0,0,0,0)", "horizontal"), a._mark = "point", m = this.deepMerge([u[b], t], "effect"), m.show && (a.effect = m), i.type === h.CHART_TYPE_MAP && (a._geo = this.getMarkGeo(u[b])), d.pack(a, i, e, u[b], b, u[b].name, r), p.push(a)));
            return p
        },_markLine: function() {
            function e(e, t) {
                e[t] = e[t] instanceof Array ? e[t].length > 1 ? e[t] : [e[t][0], e[t][0]] : [e[t], e[t]]
            }
            return function(i, n) {
                var a = this.series[i], o = this.component, r = o.dataRange, s = o.legend;
                U.merge(U.merge(n, U.clone(this.ecTheme.markLine || {})), U.clone(h.markLine));
                var l = s ? s.getColor(a.name) : this.zr.getColor(i);
                e(n, "symbol"), e(n, "symbolSize"), e(n, "symbolRotate");
                for (var c = n.data, m = [], p = this.zr.getWidth(), u = this.zr.getHeight(), g = 0; g < c.length; g++) {
                    var f = c[g];
                    if (t(f[0]) && t(f[1])) {
                        var y = this.deepMerge(f), b = [y, n], _ = l, x = null != y.value ? y.value : "";
                        if (r) {
                            _ = isNaN(x) ? _ : r.getColor(x);
                            var k = this.deepQuery(b, "itemStyle.normal.color") || _, v = this.deepQuery(b, "itemStyle.emphasis.color") || k;
                            if (null == k && null == v)
                                continue
                        }
                        f[0].tooltip = y.tooltip || n.tooltip || {trigger: "item"}, f[0].name = f[0].name || "", f[1].name = f[1].name || "", f[0].value = x, m.push({points: [[this.parsePercent(f[0].x, p), this.parsePercent(f[0].y, u)], [this.parsePercent(f[1].x, p), this.parsePercent(f[1].y, u)]],rawData: f,color: _})
                    }
                }
                var L = this.query(n, "bundling.enable");
                if (L) {
                    var w = new V;
                    w.maxTurningAngle = this.query(n, "bundling.maxTurningAngle") / 180 * Math.PI, m = w.run(m)
                }
                n.name = a.name;
                for (var W = [], g = 0, X = m.length; X > g; g++) {
                    var I = m[g], S = I.rawEdge || I, f = S.rawData, x = null != f.value ? f.value : "", K = this.getMarkLineShape(n, i, f, g, I.points, L, S.color);
                    K._mark = "line";
                    var C = this.deepMerge([f[0], f[1], n], "effect");
                    C.show && (K.effect = C, K.effect.large = n.large), a.type === h.CHART_TYPE_MAP && (K._geo = [this.getMarkGeo(f[0]), this.getMarkGeo(f[1])]), d.pack(K, a, i, f[0], g, f[0].name + ("" !== f[1].name ? " > " + f[1].name : ""), x), W.push(K)
                }
                return W
            }
        }(),getMarkCoord: function() {
            return [0, 0]
        },getSymbolShape: function(e, t, i, o, r, s, l, h, c, m, p) {
            var u = [i, e], V = this.getDataFromOption(i, "-");
            h = this.deepQuery(u, "symbol") || h;
            var U = this.deepQuery(u, "symbolSize");
            U = "function" == typeof U ? U(V) : U, "number" == typeof U && (U = [U, U]);
            var g = this.deepQuery(u, "symbolRotate"), f = this.deepMerge(u, "itemStyle.normal"), y = this.deepMerge(u, "itemStyle.emphasis"), b = null != f.borderWidth ? f.borderWidth : f.lineStyle && f.lineStyle.width;
            null == b && (b = h.match("empty") ? 2 : 0);
            var _ = null != y.borderWidth ? y.borderWidth : y.lineStyle && y.lineStyle.width;
            null == _ && (_ = b + 2);
            var x = this.getItemStyleColor(f.color, t, o, i), k = this.getItemStyleColor(y.color, t, o, i), v = U[0], L = U[1], w = new a({style: {iconType: h.replace("empty", "").toLowerCase(),x: s - v,y: l - L,width: 2 * v,height: 2 * L,brushType: "both",color: h.match("empty") ? m : x || c,strokeColor: f.borderColor || x || c,lineWidth: b},highlightStyle: {color: h.match("empty") ? m : k || x || c,strokeColor: y.borderColor || f.borderColor || k || x || c,lineWidth: _},clickable: this.deepQuery(u, "clickable")});
            return h.match("image") && (w.style.image = h.replace(new RegExp("^image:\\/\\/"), ""), w = new n({style: w.style,highlightStyle: w.highlightStyle,clickable: this.deepQuery(u, "clickable")})), null != g && (w.rotation = [g * Math.PI / 180, s, l]), h.match("star") && (w.style.iconType = "star", w.style.n = h.replace("empty", "").replace("star", "") - 0 || 5), "none" === h && (w.invisible = !0, w.hoverable = !1), w = this.addLabel(w, e, i, r, p), h.match("empty") && (null == w.style.textColor && (w.style.textColor = w.style.strokeColor), null == w.highlightStyle.textColor && (w.highlightStyle.textColor = w.highlightStyle.strokeColor)), d.pack(w, e, t, i, o, r), w._x = s, w._y = l, w._dataIndex = o, w._seriesIndex = t, w
        },getMarkLineShape: function(e, t, i, n, a, r, l) {
            var h = null != i[0].value ? i[0].value : "-", d = null != i[1].value ? i[1].value : "-", c = [i[0].symbol || e.symbol[0], i[1].symbol || e.symbol[1]], m = [i[0].symbolSize || e.symbolSize[0], i[1].symbolSize || e.symbolSize[1]];
            m[0] = "function" == typeof m[0] ? m[0](h) : m[0], m[1] = "function" == typeof m[1] ? m[1](d) : m[1];
            var p = [this.query(i[0], "symbolRotate") || e.symbolRotate[0], this.query(i[1], "symbolRotate") || e.symbolRotate[1]], u = [i[0], i[1], e], V = this.deepMerge(u, "itemStyle.normal");
            V.color = this.getItemStyleColor(V.color, t, n, i);
            var U = this.deepMerge(u, "itemStyle.emphasis");
            U.color = this.getItemStyleColor(U.color, t, n, i);
            var g = V.lineStyle, f = U.lineStyle, y = g.width;
            null == y && (y = V.borderWidth);
            var b = f.width;
            null == b && (b = null != U.borderWidth ? U.borderWidth : y + 2);
            var _ = this.deepQuery(u, "smoothness");
            this.deepQuery(u, "smooth") || (_ = 0);
            var x = r ? s : o, k = new x({style: {symbol: c,symbolSize: m,symbolRotate: p,brushType: "both",lineType: g.type,shadowColor: g.shadowColor || g.color || V.borderColor || V.color || l,shadowBlur: g.shadowBlur,shadowOffsetX: g.shadowOffsetX,shadowOffsetY: g.shadowOffsetY,color: V.color || l,strokeColor: g.color || V.borderColor || V.color || l,lineWidth: y,symbolBorderColor: V.borderColor || V.color || l,symbolBorder: V.borderWidth},highlightStyle: {shadowColor: f.shadowColor,shadowBlur: f.shadowBlur,shadowOffsetX: f.shadowOffsetX,shadowOffsetY: f.shadowOffsetY,color: U.color || V.color || l,strokeColor: f.color || g.color || U.borderColor || V.borderColor || U.color || V.color || l,lineWidth: b,symbolBorderColor: U.borderColor || V.borderColor || U.color || V.color || l,symbolBorder: null == U.borderWidth ? V.borderWidth + 2 : U.borderWidth},clickable: this.deepQuery(u, "clickable")}), v = k.style;
            return r ? (v.pointList = a, v.smooth = _) : (v.xStart = a[0][0], v.yStart = a[0][1], v.xEnd = a[1][0], v.yEnd = a[1][1], v.curveness = _, k.updatePoints(k.style)), k = this.addLabel(k, e, i[0], i[0].name + " : " + i[1].name)
        },getLargeMarkPointShape: function(e, t) {
            var i, n, a, o, s, l, h = this.series[e], d = this.component, c = t.data, m = d.dataRange, p = d.legend, u = [c[0], t];
            if (p && (n = p.getColor(h.name)), !m || (a = null != c[0].value ? c[0].value : "", n = isNaN(a) ? n : m.getColor(a), o = this.deepQuery(u, "itemStyle.normal.color") || n, s = this.deepQuery(u, "itemStyle.emphasis.color") || o, null != o || null != s)) {
                n = this.deepMerge(u, "itemStyle.normal").color || n;
                var V = this.deepQuery(u, "symbol") || "circle";
                V = V.replace("empty", "").replace(/\d/g, ""), l = this.deepMerge([c[0], t], "effect");
                var U = window.devicePixelRatio || 1;
                return i = new r({style: {pointList: c,color: n,strokeColor: n,shadowColor: l.shadowColor || n,shadowBlur: (null != l.shadowBlur ? l.shadowBlur : 8) * U,size: this.deepQuery(u, "symbolSize"),iconType: V,brushType: "fill",lineWidth: 1},draggable: !1,hoverable: !1}), l.show && (i.effect = l), i
            }
        },backupShapeList: function() {
            this.shapeList && this.shapeList.length > 0 ? (this.lastShapeList = this.shapeList, this.shapeList = []) : this.lastShapeList = []
        },addShapeList: function() {
            var e, t, i = this.option.animationThreshold / (this.canvasSupported ? 2 : 4), n = this.lastShapeList, a = this.shapeList, o = n.length > 0, r = o ? this.query(this.option, "animationDurationUpdate") : this.query(this.option, "animationDuration"), s = this.query(this.option, "animationEasing"), l = {}, d = {};
            if (this.option.animation && !this.option.renderAsImage && a.length < i && !this.motionlessOnce) {
                for (var c = 0, m = n.length; m > c; c++)
                    t = this._getAnimationKey(n[c]), t.match("undefined") ? this.zr.delShape(n[c].id) : (t += n[c].type, l[t] ? this.zr.delShape(n[c].id) : l[t] = n[c]);
                for (var c = 0, m = a.length; m > c; c++)
                    t = this._getAnimationKey(a[c]), t.match("undefined") ? this.zr.addShape(a[c]) : (t += a[c].type, d[t] = a[c]);
                for (t in l)
                    d[t] || this.zr.delShape(l[t].id);
                for (t in d)
                    l[t] ? (this.zr.delShape(l[t].id), this._animateMod(l[t], d[t], r, s, 0, o)) : (e = this.type != h.CHART_TYPE_LINE && this.type != h.CHART_TYPE_RADAR || 0 === t.indexOf("icon") ? 0 : r / 2, this._animateMod(!1, d[t], r, s, e, o));
                this.zr.refresh(), this.animationEffect()
            } else {
                this.motionlessOnce = !1, this.zr.delShape(n);
                for (var c = 0, m = a.length; m > c; c++)
                    this.zr.addShape(a[c])
            }
        },_getAnimationKey: function(e) {
            return this.type != h.CHART_TYPE_MAP && this.type != h.CHART_TYPE_TREEMAP && this.type != h.CHART_TYPE_VENN && this.type != h.CHART_TYPE_TREE ? d.get(e, "seriesIndex") + "_" + d.get(e, "dataIndex") + (e._mark ? e._mark : "") + (this.type === h.CHART_TYPE_RADAR ? d.get(e, "special") : "") : d.get(e, "seriesIndex") + "_" + d.get(e, "dataIndex") + (e._mark ? e._mark : "undefined")
        },_animateMod: function(e, t, i, n, a, o) {
            switch (t.type) {
                case "polyline":
                case "half-smooth-polygon":
                    c.pointList(this.zr, e, t, i, n);
                    break;
                case "rectangle":
                    c.rectangle(this.zr, e, t, i, n);
                    break;
                case "image":
                case "icon":
                    c.icon(this.zr, e, t, i, n, a);
                    break;
                case "candle":
                    o ? this.zr.addShape(t) : c.candle(this.zr, e, t, i, n);
                    break;
                case "ring":
                case "sector":
                case "circle":
                    o ? "sector" === t.type ? c.sector(this.zr, e, t, i, n) : this.zr.addShape(t) : c.ring(this.zr, e, t, i + (d.get(t, "dataIndex") || 0) % 20 * 100, n);
                    break;
                case "text":
                    c.text(this.zr, e, t, i, n);
                    break;
                case "polygon":
                    o ? c.pointList(this.zr, e, t, i, n) : c.polygon(this.zr, e, t, i, n);
                    break;
                case "ribbon":
                    c.ribbon(this.zr, e, t, i, n);
                    break;
                case "gauge-pointer":
                    c.gaugePointer(this.zr, e, t, i, n);
                    break;
                case "mark-line":
                    c.markline(this.zr, e, t, i, n);
                    break;
                case "bezier-curve":
                case "line":
                    c.line(this.zr, e, t, i, n);
                    break;
                default:
                    this.zr.addShape(t)
            }
        },animationMark: function(e, t, i) {
            for (var i = i || this.shapeList, n = 0, a = i.length; a > n; n++)
                i[n]._mark && this._animateMod(!1, i[n], e, t, 0, !0);
            this.animationEffect(i)
        },animationEffect: function(e) {
            if (!e && this.clearEffectShape(), e = e || this.shapeList, null != e) {
                var t = h.EFFECT_ZLEVEL;
                this.canvasSupported && this.zr.modLayer(t, {motionBlur: !0,lastFrameAlpha: this.option.effectBlendAlpha || h.effectBlendAlpha});
                for (var i, n = 0, a = e.length; a > n; n++)
                    i = e[n], i._mark && i.effect && i.effect.show && m[i._mark] && (m[i._mark](this.zr, this.effectList, i, t), this.effectList[this.effectList.length - 1]._mark = i._mark)
            }
        },clearEffectShape: function(e) {
            var t = this.effectList;
            if (this.zr && t && t.length > 0) {
                e && this.zr.modLayer(h.EFFECT_ZLEVEL, {motionBlur: !1}), this.zr.delShape(t);
                for (var i = 0; i < t.length; i++)
                    t[i].effectAnimator && t[i].effectAnimator.stop()
            }
            this.effectList = []
        },addMark: function(e, t, i) {
            var n = this.series[e];
            if (this.selectedMap[n.name]) {
                var a = this.query(this.option, "animationDurationUpdate"), o = this.query(this.option, "animationEasing"), r = n[i].data, s = this.shapeList.length;
                if (n[i].data = t.data, this["_build" + i.replace("m", "M")](e), this.option.animation && !this.option.renderAsImage)
                    this.animationMark(a, o, this.shapeList.slice(s));
                else {
                    for (var l = s, h = this.shapeList.length; h > l; l++)
                        this.zr.addShape(this.shapeList[l]);
                    this.zr.refreshNextFrame()
                }
                n[i].data = r
            }
        },delMark: function(e, t, i) {
            i = i.replace("mark", "").replace("large", "").toLowerCase();
            var n = this.series[e];
            if (this.selectedMap[n.name]) {
                for (var a = !1, o = [this.shapeList, this.effectList], r = 2; r--; )
                    for (var s = 0, l = o[r].length; l > s; s++)
                        if (o[r][s]._mark == i && d.get(o[r][s], "seriesIndex") == e && d.get(o[r][s], "name") == t) {
                            this.zr.delShape(o[r][s].id), o[r].splice(s, 1), a = !0;
                            break
                        }
                a && this.zr.refreshNextFrame()
            }
        }}, U.inherits(i, u), i
}), define("zrender/shape/Circle", ["require", "./Base", "../tool/util"], function(e) {
    "use strict";
    var t = e("./Base"), i = function(e) {
        t.call(this, e)
    };
    return i.prototype = {type: "circle",buildPath: function(e, t) {
            e.moveTo(t.x + t.r, t.y), e.arc(t.x, t.y, t.r, 0, 2 * Math.PI, !0)
        },getRect: function(e) {
            if (e.__rect)
                return e.__rect;
            var t;
            return t = "stroke" == e.brushType || "fill" == e.brushType ? e.lineWidth || 1 : 0, e.__rect = {x: Math.round(e.x - e.r - t / 2),y: Math.round(e.y - e.r - t / 2),width: 2 * e.r + t,height: 2 * e.r + t}, e.__rect
        }}, e("../tool/util").inherits(i, t), i
}), define("echarts/util/accMath", [], function() {
    function e(e, t) {
        var i = e.toString(), n = t.toString(), a = 0;
        try {
            a = n.split(".")[1].length
        } catch (o) {
        }
        try {
            a -= i.split(".")[1].length
        } catch (o) {
        }
        return (i.replace(".", "") - 0) / (n.replace(".", "") - 0) * Math.pow(10, a)
    }
    function t(e, t) {
        var i = e.toString(), n = t.toString(), a = 0;
        try {
            a += i.split(".")[1].length
        } catch (o) {
        }
        try {
            a += n.split(".")[1].length
        } catch (o) {
        }
        return (i.replace(".", "") - 0) * (n.replace(".", "") - 0) / Math.pow(10, a)
    }
    function i(e, t) {
        var i = 0, n = 0;
        try {
            i = e.toString().split(".")[1].length
        } catch (a) {
        }
        try {
            n = t.toString().split(".")[1].length
        } catch (a) {
        }
        var o = Math.pow(10, Math.max(i, n));
        return (Math.round(e * o) + Math.round(t * o)) / o
    }
    function n(e, t) {
        return i(e, -t)
    }
    return {accDiv: e,accMul: t,accAdd: i,accSub: n}
}), define("echarts/util/shape/Icon", ["require", "zrender/tool/util", "zrender/shape/Star", "zrender/shape/Heart", "zrender/shape/Droplet", "zrender/shape/Image", "zrender/shape/Base"], function(e) {
    function t(e, t) {
        var i = t.x, n = t.y, a = t.width / 16, o = t.height / 16;
        e.moveTo(i, n + t.height), e.lineTo(i + 5 * a, n + 14 * o), e.lineTo(i + t.width, n + 3 * o), e.lineTo(i + 13 * a, n), e.lineTo(i + 2 * a, n + 11 * o), e.lineTo(i, n + t.height), e.moveTo(i + 6 * a, n + 10 * o), e.lineTo(i + 14 * a, n + 2 * o), e.moveTo(i + 10 * a, n + 13 * o), e.lineTo(i + t.width, n + 13 * o), e.moveTo(i + 13 * a, n + 10 * o), e.lineTo(i + 13 * a, n + t.height)
    }
    function i(e, t) {
        var i = t.x, n = t.y, a = t.width / 16, o = t.height / 16;
        e.moveTo(i, n + t.height), e.lineTo(i + 5 * a, n + 14 * o), e.lineTo(i + t.width, n + 3 * o), e.lineTo(i + 13 * a, n), e.lineTo(i + 2 * a, n + 11 * o), e.lineTo(i, n + t.height), e.moveTo(i + 6 * a, n + 10 * o), e.lineTo(i + 14 * a, n + 2 * o), e.moveTo(i + 10 * a, n + 13 * o), e.lineTo(i + t.width, n + 13 * o)
    }
    function n(e, t) {
        var i = t.x, n = t.y, a = t.width / 16, o = t.height / 16;
        e.moveTo(i + 4 * a, n + 15 * o), e.lineTo(i + 9 * a, n + 13 * o), e.lineTo(i + 14 * a, n + 8 * o), e.lineTo(i + 11 * a, n + 5 * o), e.lineTo(i + 6 * a, n + 10 * o), e.lineTo(i + 4 * a, n + 15 * o), e.moveTo(i + 5 * a, n), e.lineTo(i + 11 * a, n), e.moveTo(i + 5 * a, n + o), e.lineTo(i + 11 * a, n + o), e.moveTo(i, n + 2 * o), e.lineTo(i + t.width, n + 2 * o), e.moveTo(i, n + 5 * o), e.lineTo(i + 3 * a, n + t.height), e.lineTo(i + 13 * a, n + t.height), e.lineTo(i + t.width, n + 5 * o)
    }
    function a(e, t) {
        var i = t.x, n = t.y, a = t.width / 16, o = t.height / 16;
        e.moveTo(i, n + 3 * o), e.lineTo(i + 6 * a, n + 3 * o), e.moveTo(i + 3 * a, n), e.lineTo(i + 3 * a, n + 6 * o), e.moveTo(i + 3 * a, n + 8 * o), e.lineTo(i + 3 * a, n + t.height), e.lineTo(i + t.width, n + t.height), e.lineTo(i + t.width, n + 3 * o), e.lineTo(i + 8 * a, n + 3 * o)
    }
    function o(e, t) {
        var i = t.x, n = t.y, a = t.width / 16, o = t.height / 16;
        e.moveTo(i + 6 * a, n), e.lineTo(i + 2 * a, n + 3 * o), e.lineTo(i + 6 * a, n + 6 * o), e.moveTo(i + 2 * a, n + 3 * o), e.lineTo(i + 14 * a, n + 3 * o), e.lineTo(i + 14 * a, n + 11 * o), e.moveTo(i + 2 * a, n + 5 * o), e.lineTo(i + 2 * a, n + 13 * o), e.lineTo(i + 14 * a, n + 13 * o), e.moveTo(i + 10 * a, n + 10 * o), e.lineTo(i + 14 * a, n + 13 * o), e.lineTo(i + 10 * a, n + t.height)
    }
    function r(e, t) {
        var i = t.x, n = t.y, a = t.width / 16, o = t.height / 16, r = t.width / 2;
        e.lineWidth = 1.5, e.arc(i + r, n + r, r - a, 0, 2 * Math.PI / 3), e.moveTo(i + 3 * a, n + t.height), e.lineTo(i + 0 * a, n + 12 * o), e.lineTo(i + 5 * a, n + 11 * o), e.moveTo(i, n + 8 * o), e.arc(i + r, n + r, r - a, Math.PI, 5 * Math.PI / 3), e.moveTo(i + 13 * a, n), e.lineTo(i + t.width, n + 4 * o), e.lineTo(i + 11 * a, n + 5 * o)
    }
    function s(e, t) {
        var i = t.x, n = t.y, a = t.width / 16, o = t.height / 16;
        e.moveTo(i, n), e.lineTo(i, n + t.height), e.lineTo(i + t.width, n + t.height), e.moveTo(i + 2 * a, n + 14 * o), e.lineTo(i + 7 * a, n + 6 * o), e.lineTo(i + 11 * a, n + 11 * o), e.lineTo(i + 15 * a, n + 2 * o)
    }
    function l(e, t) {
        var i = t.x, n = t.y, a = t.width / 16, o = t.height / 16;
        e.moveTo(i, n), e.lineTo(i, n + t.height), e.lineTo(i + t.width, n + t.height), e.moveTo(i + 3 * a, n + 14 * o), e.lineTo(i + 3 * a, n + 6 * o), e.lineTo(i + 4 * a, n + 6 * o), e.lineTo(i + 4 * a, n + 14 * o), e.moveTo(i + 7 * a, n + 14 * o), e.lineTo(i + 7 * a, n + 2 * o), e.lineTo(i + 8 * a, n + 2 * o), e.lineTo(i + 8 * a, n + 14 * o), e.moveTo(i + 11 * a, n + 14 * o), e.lineTo(i + 11 * a, n + 9 * o), e.lineTo(i + 12 * a, n + 9 * o), e.lineTo(i + 12 * a, n + 14 * o)
    }
    function h(e, t) {
        var i = t.x, n = t.y, a = t.width - 2, o = t.height - 2, r = Math.min(a, o) / 2;
        n += 2, e.moveTo(i + r + 3, n + r - 3), e.arc(i + r + 3, n + r - 3, r - 1, 0, -Math.PI / 2, !0), e.lineTo(i + r + 3, n + r - 3), e.moveTo(i + r, n), e.lineTo(i + r, n + r), e.arc(i + r, n + r, r, -Math.PI / 2, 2 * Math.PI, !0), e.lineTo(i + r, n + r), e.lineWidth = 1.5
    }
    function d(e, t) {
        var i = t.x, n = t.y, a = t.width / 16, o = t.height / 16;
        n -= o, e.moveTo(i + 1 * a, n + 2 * o), e.lineTo(i + 15 * a, n + 2 * o), e.lineTo(i + 14 * a, n + 3 * o), e.lineTo(i + 2 * a, n + 3 * o), e.moveTo(i + 3 * a, n + 6 * o), e.lineTo(i + 13 * a, n + 6 * o), e.lineTo(i + 12 * a, n + 7 * o), e.lineTo(i + 4 * a, n + 7 * o), e.moveTo(i + 5 * a, n + 10 * o), e.lineTo(i + 11 * a, n + 10 * o), e.lineTo(i + 10 * a, n + 11 * o), e.lineTo(i + 6 * a, n + 11 * o), e.moveTo(i + 7 * a, n + 14 * o), e.lineTo(i + 9 * a, n + 14 * o), e.lineTo(i + 8 * a, n + 15 * o), e.lineTo(i + 7 * a, n + 15 * o)
    }
    function c(e, t) {
        var i = t.x, n = t.y, a = t.width, o = t.height, r = a / 16, s = o / 16, l = 2 * Math.min(r, s);
        e.moveTo(i + r + l, n + s + l), e.arc(i + r, n + s, l, Math.PI / 4, 3 * Math.PI), e.lineTo(i + 7 * r - l, n + 6 * s - l), e.arc(i + 7 * r, n + 6 * s, l, Math.PI / 4 * 5, 4 * Math.PI), e.arc(i + 7 * r, n + 6 * s, l / 2, Math.PI / 4 * 5, 4 * Math.PI), e.moveTo(i + 7 * r - l / 2, n + 6 * s + l), e.lineTo(i + r + l, n + 14 * s - l), e.arc(i + r, n + 14 * s, l, -Math.PI / 4, 2 * Math.PI), e.moveTo(i + 7 * r + l / 2, n + 6 * s), e.lineTo(i + 14 * r - l, n + 10 * s - l / 2), e.moveTo(i + 16 * r, n + 10 * s), e.arc(i + 14 * r, n + 10 * s, l, 0, 3 * Math.PI), e.lineWidth = 1.5
    }
    function m(e, t) {
        var i = t.x, n = t.y, a = t.width, o = t.height, r = Math.min(a, o) / 2;
        e.moveTo(i + a, n + o / 2), e.arc(i + r, n + r, r, 0, 2 * Math.PI), e.arc(i + r, n, r, Math.PI / 4, Math.PI / 5 * 4), e.arc(i, n + r, r, -Math.PI / 3, Math.PI / 3), e.arc(i + a, n + o, r, Math.PI, Math.PI / 2 * 3), e.lineWidth = 1.5
    }
    function p(e, t) {
        for (var i = t.x, n = t.y, a = t.width, o = t.height, r = Math.round(o / 3), s = Math.round((r - 2) / 2), l = 3; l--; )
            e.rect(i, n + r * l + s, a, 2)
    }
    function u(e, t) {
        for (var i = t.x, n = t.y, a = t.width, o = t.height, r = Math.round(a / 3), s = Math.round((r - 2) / 2), l = 3; l--; )
            e.rect(i + r * l + s, n, 2, o)
    }
    function V(e, t) {
        var i = t.x, n = t.y, a = t.width / 16;
        e.moveTo(i + a, n), e.lineTo(i + a, n + t.height), e.lineTo(i + 15 * a, n + t.height), e.lineTo(i + 15 * a, n), e.lineTo(i + a, n), e.moveTo(i + 3 * a, n + 3 * a), e.lineTo(i + 13 * a, n + 3 * a), e.moveTo(i + 3 * a, n + 6 * a), e.lineTo(i + 13 * a, n + 6 * a), e.moveTo(i + 3 * a, n + 9 * a), e.lineTo(i + 13 * a, n + 9 * a), e.moveTo(i + 3 * a, n + 12 * a), e.lineTo(i + 9 * a, n + 12 * a)
    }
    function U(e, t) {
        var i = t.x, n = t.y, a = t.width / 16, o = t.height / 16;
        e.moveTo(i, n), e.lineTo(i, n + t.height), e.lineTo(i + t.width, n + t.height), e.lineTo(i + t.width, n), e.lineTo(i, n), e.moveTo(i + 4 * a, n), e.lineTo(i + 4 * a, n + 8 * o), e.lineTo(i + 12 * a, n + 8 * o), e.lineTo(i + 12 * a, n), e.moveTo(i + 6 * a, n + 11 * o), e.lineTo(i + 6 * a, n + 13 * o), e.lineTo(i + 10 * a, n + 13 * o), e.lineTo(i + 10 * a, n + 11 * o), e.lineTo(i + 6 * a, n + 11 * o)
    }
    function g(e, t) {
        var i = t.x, n = t.y, a = t.width, o = t.height;
        e.moveTo(i, n + o / 2), e.lineTo(i + a, n + o / 2), e.moveTo(i + a / 2, n), e.lineTo(i + a / 2, n + o)
    }
    function f(e, t) {
        var i = t.width / 2, n = t.height / 2, a = Math.min(i, n);
        e.moveTo(t.x + i + a, t.y + n), e.arc(t.x + i, t.y + n, a, 0, 2 * Math.PI), e.closePath()
    }
    function y(e, t) {
        e.rect(t.x, t.y, t.width, t.height), e.closePath()
    }
    function b(e, t) {
        var i = t.width / 2, n = t.height / 2, a = t.x + i, o = t.y + n, r = Math.min(i, n);
        e.moveTo(a, o - r), e.lineTo(a + r, o + r), e.lineTo(a - r, o + r), e.lineTo(a, o - r), e.closePath()
    }
    function _(e, t) {
        var i = t.width / 2, n = t.height / 2, a = t.x + i, o = t.y + n, r = Math.min(i, n);
        e.moveTo(a, o - r), e.lineTo(a + r, o), e.lineTo(a, o + r), e.lineTo(a - r, o), e.lineTo(a, o - r), e.closePath()
    }
    function x(e, t) {
        var i = t.x, n = t.y, a = t.width / 16;
        e.moveTo(i + 8 * a, n), e.lineTo(i + a, n + t.height), e.lineTo(i + 8 * a, n + t.height / 4 * 3), e.lineTo(i + 15 * a, n + t.height), e.lineTo(i + 8 * a, n), e.closePath()
    }
    function k(t, i) {
        var n = e("zrender/shape/Star"), a = i.width / 2, o = i.height / 2;
        n.prototype.buildPath(t, {x: i.x + a,y: i.y + o,r: Math.min(a, o),n: i.n || 5})
    }
    function v(t, i) {
        var n = e("zrender/shape/Heart");
        n.prototype.buildPath(t, {x: i.x + i.width / 2,y: i.y + .2 * i.height,a: i.width / 2,b: .8 * i.height})
    }
    function L(t, i) {
        var n = e("zrender/shape/Droplet");
        n.prototype.buildPath(t, {x: i.x + .5 * i.width,y: i.y + .5 * i.height,a: .5 * i.width,b: .8 * i.height})
    }
    function w(e, t) {
        var i = t.x, n = t.y - t.height / 2 * 1.5, a = t.width / 2, o = t.height / 2, r = Math.min(a, o);
        e.arc(i + a, n + o, r, Math.PI / 5 * 4, Math.PI / 5), e.lineTo(i + a, n + o + 1.5 * r), e.closePath()
    }
    function W(t, i, n) {
        var a = e("zrender/shape/Image");
        this._imageShape = this._imageShape || new a({style: {}});
        for (var o in i)
            this._imageShape.style[o] = i[o];
        this._imageShape.brush(t, !1, n)
    }
    function X(e) {
        S.call(this, e)
    }
    var I = e("zrender/tool/util"), S = e("zrender/shape/Base");
    return X.prototype = {type: "icon",iconLibrary: {mark: t,markUndo: i,markClear: n,dataZoom: a,dataZoomReset: o,restore: r,lineChart: s,barChart: l,pieChart: h,funnelChart: d,forceChart: c,chordChart: m,stackChart: p,tiledChart: u,dataView: V,saveAsImage: U,cross: g,circle: f,rectangle: y,triangle: b,diamond: _,arrow: x,star: k,heart: v,droplet: L,pin: w,image: W},brush: function(t, i, n) {
            var a = i ? this.highlightStyle : this.style;
            a = a || {};
            var o = a.iconType || this.style.iconType;
            if ("image" === o) {
                var r = e("zrender/shape/Image");
                r.prototype.brush.call(this, t, i, n)
            } else {
                var a = this.beforeBrush(t, i);
                switch (t.beginPath(), this.buildPath(t, a, n), a.brushType) {
                    case "both":
                        t.fill();
                    case "stroke":
                        a.lineWidth > 0 && t.stroke();
                        break;
                    default:
                        t.fill()
                }
                this.drawText(t, a, this.style), this.afterBrush(t)
            }
        },buildPath: function(e, t, i) {
            this.iconLibrary[t.iconType] ? this.iconLibrary[t.iconType].call(this, e, t, i) : (e.moveTo(t.x, t.y), e.lineTo(t.x + t.width, t.y), e.lineTo(t.x + t.width, t.y + t.height), e.lineTo(t.x, t.y + t.height), e.lineTo(t.x, t.y), e.closePath())
        },getRect: function(e) {
            return e.__rect ? e.__rect : (e.__rect = {x: Math.round(e.x),y: Math.round(e.y - ("pin" == e.iconType ? e.height / 2 * 1.5 : 0)),width: e.width,height: e.height * ("pin" === e.iconType ? 1.25 : 1)}, e.__rect)
        },isCover: function(e, t) {
            var i = this.transformCoordToLocal(e, t);
            e = i[0], t = i[1];
            var n = this.style.__rect;
            n || (n = this.style.__rect = this.getRect(this.style));
            var a = n.height < 8 || n.width < 8 ? 4 : 0;
            return e >= n.x - a && e <= n.x + n.width + a && t >= n.y - a && t <= n.y + n.height + a
        }}, I.inherits(X, S), X
}), define("echarts/util/shape/MarkLine", ["require", "zrender/shape/Base", "./Icon", "zrender/shape/Line", "zrender/shape/BezierCurve", "zrender/tool/area", "zrender/shape/util/dashedLineTo", "zrender/tool/util", "zrender/tool/curve"], function(e) {
    function t(e) {
        i.call(this, e), this.style.curveness > 0 && this.updatePoints(this.style), this.highlightStyle.curveness > 0 && this.updatePoints(this.highlightStyle)
    }
    var i = e("zrender/shape/Base"), n = e("./Icon"), a = e("zrender/shape/Line"), o = new a({}), r = e("zrender/shape/BezierCurve"), s = new r({}), l = e("zrender/tool/area"), h = e("zrender/shape/util/dashedLineTo"), d = e("zrender/tool/util"), c = e("zrender/tool/curve");
    return t.prototype = {type: "mark-line",brush: function(e, t) {
            var i = this.style;
            t && (i = this.getHighlightStyle(i, this.highlightStyle || {})), e.save(), this.setContext(e, i), this.setTransform(e), e.save(), e.beginPath(), this.buildPath(e, i), e.stroke(), e.restore(), this.brushSymbol(e, i, 0), this.brushSymbol(e, i, 1), this.drawText(e, i, this.style), e.restore()
        },buildPath: function(e, t) {
            var i = t.lineType || "solid";
            
            if (e.moveTo(t.xStart, t.yStart), t.curveness > 0) {
                var n = null;
                switch (i) {
                    case "dashed":
                        n = [5, 5];
                        break;
                    case "dotted":
                        n = [1, 1]
                }
                n && e.setLineDash && e.setLineDash(n), e.quadraticCurveTo(t.cpX1, t.cpY1, t.xEnd, t.yEnd)
            } else if ("solid" == i)
                e.lineTo(t.xEnd, t.yEnd);
            else {
                var a = (t.lineWidth || 1) * ("dashed" == t.lineType ? 5 : 1);
                h(e, t.xStart, t.yStart, t.xEnd, t.yEnd, a)
            }
        },updatePoints: function(e) {
            var t = e.curveness || 0, i = 1, n = e.xStart, a = e.yStart, o = e.xEnd, r = e.yEnd, s = (n + o) / 2 - i * (a - r) * t, l = (a + r) / 2 - i * (o - n) * t;
            e.cpX1 = s, e.cpY1 = l
        },brushSymbol: function(e, t, i) {
            if ("none" != t.symbol[i]) {
                e.save(), e.beginPath(), e.lineWidth = t.symbolBorder, e.strokeStyle = t.symbolBorderColor;
                var a = t.symbol[i].replace("empty", "").toLowerCase();
                t.symbol[i].match("empty") && (e.fillStyle = "#fff");
                var o = t.xStart, r = t.yStart, s = t.xEnd, l = t.yEnd, h = 0 === i ? o : s, d = 0 === i ? r : l, m = t.curveness || 0, p = null != t.symbolRotate[i] ? t.symbolRotate[i] - 0 : 0;
                if (p = p / 180 * Math.PI, "arrow" == a && 0 === p)
                    if (0 === m) {
                        var u = 0 === i ? -1 : 1;
                        p = Math.PI / 2 + Math.atan2(u * (l - r), u * (s - o))
                    } else {
                        var V = t.cpX1, U = t.cpY1, g = c.quadraticDerivativeAt, f = g(o, V, s, i), y = g(r, U, l, i);
                        p = Math.PI / 2 + Math.atan2(y, f)
                    }
                e.translate(h, d), 0 !== p && e.rotate(p);
                var b = t.symbolSize[i];
                n.prototype.buildPath(e, {x: -b,y: -b,width: 2 * b,height: 2 * b,iconType: a}), e.closePath(), e.fill(), e.stroke(), e.restore()
            }
        },getRect: function(e) {
            return e.curveness > 0 ? s.getRect(e) : o.getRect(e), e.__rect
        },isCover: function(e, t) {
            var i = this.transformCoordToLocal(e, t);
            return e = i[0], t = i[1], this.isCoverRect(e, t) ? this.style.curveness > 0 ? l.isInside(s, this.style, e, t) : l.isInside(o, this.style, e, t) : !1
        }}, d.inherits(t, i), t
}), define("echarts/util/shape/Symbol", ["require", "zrender/shape/Base", "zrender/shape/Polygon", "zrender/tool/util", "./normalIsCover"], function(e) {
    function t(e) {
        i.call(this, e)
    }
    var i = e("zrender/shape/Base"), n = e("zrender/shape/Polygon"), a = new n({}), o = e("zrender/tool/util");
    return t.prototype = {type: "symbol",buildPath: function(e, t) {
            var i = t.pointList, n = i.length;
            if (0 !== n)
                for (var a, o, r, s, l, h = 1e4, d = Math.ceil(n / h), c = i[0] instanceof Array, m = t.size ? t.size : 2, p = m, u = m / 2, V = 2 * Math.PI, U = 0; d > U; U++) {
                    e.beginPath(), a = U * h, o = a + h, o = o > n ? n : o;
                    for (var g = a; o > g; g++)
                        if (t.random && (r = t["randomMap" + g % 20] / 100, p = m * r * r, u = p / 2), c ? (s = i[g][0], l = i[g][1]) : (s = i[g].x, l = i[g].y), 3 > p)
                            e.rect(s - u, l - u, p, p);
                        else
                            switch (t.iconType) {
                                case "circle":
                                    e.moveTo(s, l), e.arc(s, l, u, 0, V, !0);
                                    break;
                                case "diamond":
                                    e.moveTo(s, l - u), e.lineTo(s + u / 3, l - u / 3), e.lineTo(s + u, l), e.lineTo(s + u / 3, l + u / 3), e.lineTo(s, l + u), e.lineTo(s - u / 3, l + u / 3), e.lineTo(s - u, l), e.lineTo(s - u / 3, l - u / 3), e.lineTo(s, l - u);
                                    break;
                                default:
                                    e.rect(s - u, l - u, p, p)
                            }
                    if (e.closePath(), d - 1 > U)
                        switch (t.brushType) {
                            case "both":
                                e.fill(), t.lineWidth > 0 && e.stroke();
                                break;
                            case "stroke":
                                t.lineWidth > 0 && e.stroke();
                                break;
                            default:
                                e.fill()
                        }
                }
        },getRect: function(e) {
            return e.__rect || a.getRect(e)
        },isCover: e("./normalIsCover")}, o.inherits(t, i), t
}), define("zrender/shape/Polyline", ["require", "./Base", "./util/smoothSpline", "./util/smoothBezier", "./util/dashedLineTo", "./Polygon", "../tool/util"], function(e) {
    var t = e("./Base"), i = e("./util/smoothSpline"), n = e("./util/smoothBezier"), a = e("./util/dashedLineTo"), o = function(e) {
        this.brushTypeOnly = "stroke", this.textPosition = "end", t.call(this, e)
    };
    return o.prototype = {type: "polyline",buildPath: function(e, t) {
            var n = t.pointList;
            if (!(n.length < 2)) {
                var o = Math.min(t.pointList.length, Math.round(t.pointListLength || t.pointList.length));
                if (t.smooth && "spline" !== t.smooth) {
                    t.controlPointList || this.updateControlPoints(t);
                    var r = t.controlPointList;
                    e.moveTo(n[0][0], n[0][1]);
                    for (var s, l, h, d = 0; o - 1 > d; d++)
                        s = r[2 * d], l = r[2 * d + 1], h = n[d + 1], e.bezierCurveTo(s[0], s[1], l[0], l[1], h[0], h[1])
                } else if ("spline" === t.smooth && (n = i(n), o = n.length), t.lineType && "solid" != t.lineType) {
                    if ("dashed" == t.lineType || "dotted" == t.lineType) {
                        var c = (t.lineWidth || 1) * ("dashed" == t.lineType ? 5 : 1);
                        e.moveTo(n[0][0], n[0][1]);
                        for (var d = 1; o > d; d++)
                            a(e, n[d - 1][0], n[d - 1][1], n[d][0], n[d][1], c)
                    }
                } else {
                    e.moveTo(n[0][0], n[0][1]);
                    for (var d = 1; o > d; d++)
                        e.lineTo(n[d][0], n[d][1])
                }
            }
        },updateControlPoints: function(e) {
            e.controlPointList = n(e.pointList, e.smooth, !1, e.smoothConstraint)
        },getRect: function(t) {
            return e("./Polygon").prototype.getRect(t)
        }}, e("../tool/util").inherits(o, t), o
}), define("zrender/shape/ShapeBundle", ["require", "./Base", "../tool/util"], function(e) {
    var t = e("./Base"), i = function(e) {
        t.call(this, e)
    };
    return i.prototype = {constructor: i,type: "shape-bundle",brush: function(e, t) {
            var i = this.beforeBrush(e, t);
            e.beginPath();
            for (var n = 0; n < i.shapeList.length; n++) {
                var a = i.shapeList[n], o = a.style;
                t && (o = a.getHighlightStyle(o, a.highlightStyle || {}, a.brushTypeOnly)), a.buildPath(e, o)
            }
            switch (i.brushType) {
                case "both":
                    e.fill();
                case "stroke":
                    i.lineWidth > 0 && e.stroke();
                    break;
                default:
                    e.fill()
            }
            this.drawText(e, i, this.style), this.afterBrush(e)
        },getRect: function(e) {
            if (e.__rect)
                return e.__rect;
            for (var t = 1 / 0, i = -(1 / 0), n = 1 / 0, a = -(1 / 0), o = 0; o < e.shapeList.length; o++)
                var r = e.shapeList[o], s = r.getRect(r.style), t = Math.min(s.x, t), n = Math.min(s.y, n), i = Math.max(s.x + s.width, i), a = Math.max(s.y + s.height, a);
            return e.__rect = {x: t,y: n,width: i - t,height: a - n}, e.__rect
        },isCover: function(e, t) {
            var i = this.transformCoordToLocal(e, t);
            if (e = i[0], t = i[1], this.isCoverRect(e, t))
                for (var n = 0; n < this.style.shapeList.length; n++) {
                    var a = this.style.shapeList[n];
                    if (a.isCover(e, t))
                        return !0
                }
            return !1
        }}, e("../tool/util").inherits(i, t), i
}), define("echarts/util/ecAnimation", ["require", "zrender/tool/util", "zrender/tool/curve", "zrender/shape/Polygon"], function(e) {
    function t(e, t, i, n, a) {
        var o, r = i.style.pointList, s = r.length;
        if (!t) {
            if (o = [], "vertical" != i._orient)
                for (var l = r[0][1], h = 0; s > h; h++)
                    o[h] = [r[h][0], l];
            else
                for (var d = r[0][0], h = 0; s > h; h++)
                    o[h] = [d, r[h][1]];
            "half-smooth-polygon" == i.type && (o[s - 1] = u.clone(r[s - 1]), o[s - 2] = u.clone(r[s - 2])), t = {style: {pointList: o}}
        }
        o = t.style.pointList;
        var c = o.length;
        i.style.pointList = c == s ? o : s > c ? o.concat(r.slice(c)) : o.slice(0, s), e.addShape(i), i.__animating = !0, e.animate(i.id, "style").when(n, {pointList: r}).during(function() {
            i.updateControlPoints && i.updateControlPoints(i.style)
        }).done(function() {
            i.__animating = !1
        }).start(a)
    }
    function i(e, t) {
        for (var i = arguments.length, n = 2; i > n; n++) {
            var a = arguments[n];
            e.style[a] = t.style[a]
        }
    }
    function n(e, t, n, a, o) {
        var r = n.style;
        t || (t = {position: n.position,style: {x: r.x,y: "vertical" == n._orient ? r.y + r.height : r.y,width: "vertical" == n._orient ? r.width : 0,height: "vertical" != n._orient ? r.height : 0}});
        var s = r.x, l = r.y, h = r.width, d = r.height, c = [n.position[0], n.position[1]];
        i(n, t, "x", "y", "width", "height"), n.position = t.position, e.addShape(n), (c[0] != t.position[0] || c[1] != t.position[1]) && e.animate(n.id, "").when(a, {position: c}).start(o), n.__animating = !0, e.animate(n.id, "style").when(a, {x: s,y: l,width: h,height: d}).done(function() {
            n.__animating = !1
        }).start(o)
    }
    function a(e, t, i, n, a) {
        if (!t) {
            var o = i.style.y;
            t = {style: {y: [o[0], o[0], o[0], o[0]]}}
        }
        var r = i.style.y;
        i.style.y = t.style.y, e.addShape(i), i.__animating = !0, e.animate(i.id, "style").when(n, {y: r}).done(function() {
            i.__animating = !1
        }).start(a)
    }
    function o(e, t, i, n, a) {
        var o = i.style.x, r = i.style.y, s = i.style.r0, l = i.style.r;
        i.__animating = !0, "r" != i._animationAdd ? (i.style.r0 = 0, i.style.r = 0, i.rotation = [2 * Math.PI, o, r], e.addShape(i), e.animate(i.id, "style").when(n, {r0: s,r: l}).done(function() {
            i.__animating = !1
        }).start(a), e.animate(i.id, "").when(n, {rotation: [0, o, r]}).start(a)) : (i.style.r0 = i.style.r, e.addShape(i), e.animate(i.id, "style").when(n, {r0: s}).done(function() {
            i.__animating = !1
        }).start(a))
    }
    function r(e, t, n, a, o) {
        t || (t = "r" != n._animationAdd ? {style: {startAngle: n.style.startAngle,endAngle: n.style.startAngle}} : {style: {r0: n.style.r}});
        var r = n.style.startAngle, s = n.style.endAngle;
        i(n, t, "startAngle", "endAngle"), e.addShape(n), n.__animating = !0, e.animate(n.id, "style").when(a, {startAngle: r,endAngle: s}).done(function() {
            n.__animating = !1
        }).start(o)
    }
    function s(e, t, n, a, o) {
        t || (t = {style: {x: "left" == n.style.textAlign ? n.style.x + 100 : n.style.x - 100,y: n.style.y}});
        var r = n.style.x, s = n.style.y;
        i(n, t, "x", "y"), e.addShape(n), n.__animating = !0, e.animate(n.id, "style").when(a, {x: r,y: s}).done(function() {
            n.__animating = !1
        }).start(o)
    }
    function l(t, i, n, a, o) {
        var r = e("zrender/shape/Polygon").prototype.getRect(n.style), s = r.x + r.width / 2, l = r.y + r.height / 2;
        n.scale = [.1, .1, s, l], t.addShape(n), n.__animating = !0, t.animate(n.id, "").when(a, {scale: [1, 1, s, l]}).done(function() {
            n.__animating = !1
        }).start(o)
    }
    function h(e, t, n, a, o) {
        t || (t = {style: {source0: 0,source1: n.style.source1 > 0 ? 360 : -360,target0: 0,target1: n.style.target1 > 0 ? 360 : -360}});
        var r = n.style.source0, s = n.style.source1, l = n.style.target0, h = n.style.target1;
        t.style && i(n, t, "source0", "source1", "target0", "target1"), e.addShape(n), n.__animating = !0, e.animate(n.id, "style").when(a, {source0: r,source1: s,target0: l,target1: h}).done(function() {
            n.__animating = !1
        }).start(o)
    }
    function d(e, t, i, n, a) {
        t || (t = {style: {angle: i.style.startAngle}});
        var o = i.style.angle;
        i.style.angle = t.style.angle, e.addShape(i), i.__animating = !0, e.animate(i.id, "style").when(n, {angle: o}).done(function() {
            i.__animating = !1
        }).start(a)
    }
    function c(e, t, i, a, o, r) {
        if (i.style._x = i.style.x, i.style._y = i.style.y, i.style._width = i.style.width, i.style._height = i.style.height, t)
            n(e, t, i, a, o);
        else {
            var s = i._x || 0, l = i._y || 0;
            i.scale = [.01, .01, s, l], e.addShape(i), i.__animating = !0, e.animate(i.id, "").delay(r).when(a, {scale: [1, 1, s, l]}).done(function() {
                i.__animating = !1
            }).start(o || "QuinticOut")
        }
    }
    function m(e, t, n, a, o) {
        t || (t = {style: {xStart: n.style.xStart,yStart: n.style.yStart,xEnd: n.style.xStart,yEnd: n.style.yStart}});
        var r = n.style.xStart, s = n.style.xEnd, l = n.style.yStart, h = n.style.yEnd;
        i(n, t, "xStart", "xEnd", "yStart", "yEnd"), e.addShape(n), n.__animating = !0, e.animate(n.id, "style").when(a, {xStart: r,xEnd: s,yStart: l,yEnd: h}).done(function() {
            n.__animating = !1
        }).start(o)
    }
    function p(e, t, i, n, a) {
        a = a || "QuinticOut", i.__animating = !0, e.addShape(i);
        var o = i.style, r = function() {
            i.__animating = !1
        }, s = o.xStart, l = o.yStart, h = o.xEnd, d = o.yEnd;
        if (o.curveness > 0) {
            i.updatePoints(o);
            var c = {p: 0}, m = o.cpX1, p = o.cpY1, u = [], U = [], g = V.quadraticSubdivide;
            e.animation.animate(c).when(n, {p: 1}).during(function() {
                g(s, m, h, c.p, u), g(l, p, d, c.p, U), o.cpX1 = u[1], o.cpY1 = U[1], o.xEnd = u[2], o.yEnd = U[2], e.modShape(i)
            }).done(r).start(a)
        } else
            e.animate(i.id, "style").when(0, {xEnd: s,yEnd: l}).when(n, {xEnd: h,yEnd: d}).done(r).start(a)
    }
    var u = e("zrender/tool/util"), V = e("zrender/tool/curve");
    return {pointList: t,rectangle: n,candle: a,ring: o,sector: r,text: s,polygon: l,ribbon: h,gaugePointer: d,icon: c,line: m,markline: p}
}), define("echarts/util/ecEffect", ["require", "../util/ecData", "zrender/shape/Circle", "zrender/shape/Image", "zrender/tool/curve", "../util/shape/Icon", "../util/shape/Symbol", "zrender/shape/ShapeBundle", "zrender/shape/Polyline", "zrender/tool/vector", "zrender/tool/env"], function(e) {
    function t(e, t, i, n) {
        var a, r = i.effect, l = r.color || i.style.strokeColor || i.style.color, d = r.shadowColor || l, c = r.scaleSize, m = r.bounceDistance, p = "undefined" != typeof r.shadowBlur ? r.shadowBlur : c;
        "image" !== i.type ? (a = new h({zlevel: n,style: {brushType: "stroke",iconType: "droplet" != i.style.iconType ? i.style.iconType : "circle",x: p + 1,y: p + 1,n: i.style.n,width: i.style._width * c,height: i.style._height * c,lineWidth: 1,strokeColor: l,shadowColor: d,shadowBlur: p},draggable: !1,hoverable: !1}), "pin" == i.style.iconType && (a.style.y += a.style.height / 2 * 1.5), u && (a.style.image = e.shapeToImage(a, a.style.width + 2 * p + 2, a.style.height + 2 * p + 2).style.image, a = new s({zlevel: a.zlevel,style: a.style,draggable: !1,hoverable: !1}))) : a = new s({zlevel: n,style: i.style,draggable: !1,hoverable: !1}), o.clone(i, a), a.position = i.position, t.push(a), e.addShape(a);
        var V = "image" !== i.type ? window.devicePixelRatio || 1 : 1, U = (a.style.width / V - i.style._width) / 2;
        a.style.x = i.style._x - U, a.style.y = i.style._y - U, "pin" == i.style.iconType && (a.style.y -= i.style.height / 2 * 1.5);
        var g = 100 * (r.period + 10 * Math.random());
        e.modShape(i.id, {invisible: !0});
        var f = a.style.x + a.style.width / 2 / V, y = a.style.y + a.style.height / 2 / V;
        "scale" === r.type ? (e.modShape(a.id, {scale: [.1, .1, f, y]}), e.animate(a.id, "", r.loop).when(g, {scale: [1, 1, f, y]}).done(function() {
            i.effect.show = !1, e.delShape(a.id)
        }).start()) : e.animate(a.id, "style", r.loop).when(g, {y: a.style.y - m}).when(2 * g, {y: a.style.y}).done(function() {
            i.effect.show = !1, e.delShape(a.id)
        }).start()
    }
    function i(e, t, i, n) {
        var a = i.effect, o = a.color || i.style.strokeColor || i.style.color, r = a.scaleSize, s = a.shadowColor || o, l = "undefined" != typeof a.shadowBlur ? a.shadowBlur : 2 * r, h = window.devicePixelRatio || 1, c = new d({zlevel: n,position: i.position,scale: i.scale,style: {pointList: i.style.pointList,iconType: i.style.iconType,color: o,strokeColor: o,shadowColor: s,shadowBlur: l * h,random: !0,brushType: "fill",lineWidth: 1,size: i.style.size},draggable: !1,hoverable: !1});
        t.push(c), e.addShape(c), e.modShape(i.id, {invisible: !0});
        for (var m = Math.round(100 * a.period), p = {}, u = {}, V = 0; 20 > V; V++)
            c.style["randomMap" + V] = 0, p = {}, p["randomMap" + V] = 100, u = {}, u["randomMap" + V] = 0, c.style["randomMap" + V] = 100 * Math.random(), e.animate(c.id, "style", !0).when(m, p).when(2 * m, u).when(3 * m, p).when(4 * m, p).delay(Math.random() * m * V).start()
    }
    function n(e, t, i, n, a) {
        var s = i.effect, h = i.style, d = s.color || h.strokeColor || h.color, c = s.shadowColor || h.strokeColor || d, V = h.lineWidth * s.scaleSize, U = "undefined" != typeof s.shadowBlur ? s.shadowBlur : V, g = new r({zlevel: n,style: {x: U,y: U,r: V,color: d,shadowColor: c,shadowBlur: U},hoverable: !1}), f = 0;
        if (u && !a) {
            var n = g.zlevel;
            g = e.shapeToImage(g, 2 * (V + U), 2 * (V + U)), g.zlevel = n, g.hoverable = !1, f = U
        }
        a || (o.clone(i, g), g.position = i.position, t.push(g), e.addShape(g));
        var y = function() {
            a || (i.effect.show = !1, e.delShape(g.id)), g.effectAnimator = null
        };
        if (i instanceof m) {
            for (var b = [0], _ = 0, x = h.pointList, k = h.controlPointList, v = 1; v < x.length; v++) {
                if (k) {
                    var L = k[2 * (v - 1)], w = k[2 * (v - 1) + 1];
                    _ += p.dist(x[v - 1], L) + p.dist(L, w) + p.dist(w, x[v])
                } else
                    _ += p.dist(x[v - 1], x[v]);
                b.push(_)
            }
            for (var W = {p: 0}, X = e.animation.animate(W, {loop: s.loop}), v = 0; v < b.length; v++)
                X.when(b[v] * s.period, {p: v});
            X.during(function() {
                var t, i, n = Math.floor(W.p);
                if (n == x.length - 1)
                    t = x[n][0], i = x[n][1];
                else {
                    var o = W.p - n, r = x[n], s = x[n + 1];
                    if (k) {
                        var h = k[2 * n], d = k[2 * n + 1];
                        t = l.cubicAt(r[0], h[0], d[0], s[0], o), i = l.cubicAt(r[1], h[1], d[1], s[1], o)
                    } else
                        t = (s[0] - r[0]) * o + r[0], i = (s[1] - r[1]) * o + r[1]
                }
                g.style.x = t, g.style.y = i, a || e.modShape(g)
            }).done(y).start(), X.duration = _ * s.period, g.effectAnimator = X
        } else {
            var I = h.xStart - f, S = h.yStart - f, K = h.xEnd - f, C = h.yEnd - f;
            g.style.x = I, g.style.y = S;
            var T = (K - I) * (K - I) + (C - S) * (C - S), E = Math.round(Math.sqrt(Math.round(T * s.period * s.period)));
            if (i.style.curveness > 0) {
                var z = h.cpX1 - f, A = h.cpY1 - f;
                g.effectAnimator = e.animation.animate(g, {loop: s.loop}).when(E, {p: 1}).during(function(t, i) {
                    g.style.x = l.quadraticAt(I, z, K, i), g.style.y = l.quadraticAt(S, A, C, i), a || e.modShape(g)
                }).done(y).start()
            } else
                g.effectAnimator = e.animation.animate(g.style, {loop: s.loop}).when(E, {x: K,y: C}).during(function() {
                    a || e.modShape(g)
                }).done(y).start();
            g.effectAnimator.duration = E
        }
        return g
    }
    function a(e, t, i, a) {
        var o = new c({style: {shapeList: []},zlevel: a,hoverable: !1}), r = i.style.shapeList, s = i.effect;
        o.position = i.position;
        for (var l = 0, h = [], d = 0; d < r.length; d++) {
            r[d].effect = s;
            var m = n(e, null, r[d], a, !0), p = m.effectAnimator;
            o.style.shapeList.push(m), p.duration > l && (l = p.duration), 0 === d && (o.style.color = m.style.color, o.style.shadowBlur = m.style.shadowBlur, o.style.shadowColor = m.style.shadowColor), h.push(p)
        }
        t.push(o), e.addShape(o);
        var u = function() {
            for (var e = 0; e < h.length; e++)
                h[e].stop()
        };
        if (l) {
            o.__dummy = 0;
            var V = e.animate(o.id, "", s.loop).when(l, {__dummy: 1}).during(function() {
                e.modShape(o)
            }).done(function() {
                i.effect.show = !1, e.delShape(o.id)
            }).start(), U = V.stop;
            V.stop = function() {
                u(), U.call(this)
            }
        }
    }
    var o = e("../util/ecData"), r = e("zrender/shape/Circle"), s = e("zrender/shape/Image"), l = e("zrender/tool/curve"), h = e("../util/shape/Icon"), d = e("../util/shape/Symbol"), c = e("zrender/shape/ShapeBundle"), m = e("zrender/shape/Polyline"), p = e("zrender/tool/vector"), u = e("zrender/tool/env").canvasSupported;
    return {point: t,largePoint: i,line: n,largeLine: a}
}), define("echarts/component/base", ["require", "../config", "../util/ecData", "../util/ecQuery", "../util/number", "zrender/tool/util", "zrender/tool/env"], function(e) {
    function t(e, t, a, o, r) {
        this.ecTheme = e, this.messageCenter = t, this.zr = a, this.option = o, this.series = o.series, this.myChart = r, this.component = r.component, this.shapeList = [], this.effectList = [];
        var s = this;
        s._onlegendhoverlink = function(e) {
            if (s.legendHoverLink)
                for (var t, a = e.target, o = s.shapeList.length - 1; o >= 0; o--)
                    t = s.type == i.CHART_TYPE_PIE || s.type == i.CHART_TYPE_FUNNEL ? n.get(s.shapeList[o], "name") : (n.get(s.shapeList[o], "series") || {}).name, t != a || s.shapeList[o].invisible || s.shapeList[o].__animating || s.zr.addHoverShape(s.shapeList[o])
        }, t && t.bind(i.EVENT.LEGEND_HOVERLINK, this._onlegendhoverlink)
    }
    var i = e("../config"), n = e("../util/ecData"), a = e("../util/ecQuery"), o = e("../util/number"), r = e("zrender/tool/util");
    return t.prototype = {canvasSupported: e("zrender/tool/env").canvasSupported,_getZ: function(e) {
            if (null != this[e])
                return this[e];
            var t = this.ecTheme[this.type];
            return t && null != t[e] ? t[e] : (t = i[this.type], t && null != t[e] ? t[e] : 0)
        },getZlevelBase: function() {
            return this._getZ("zlevel")
        },getZBase: function() {
            return this._getZ("z")
        },reformOption: function(e) {
            return e = r.merge(r.merge(e || {}, r.clone(this.ecTheme[this.type] || {})), r.clone(i[this.type] || {})), this.z = e.z, this.zlevel = e.zlevel, e
        },reformCssArray: function(e) {
            if (!(e instanceof Array))
                return [e, e, e, e];
            switch (e.length + "") {
                case "4":
                    return e;
                case "3":
                    return [e[0], e[1], e[2], e[1]];
                case "2":
                    return [e[0], e[1], e[0], e[1]];
                case "1":
                    return [e[0], e[0], e[0], e[0]];
                case "0":
                    return [0, 0, 0, 0]
            }
        },getShapeById: function(e) {
            for (var t = 0, i = this.shapeList.length; i > t; t++)
                if (this.shapeList[t].id === e)
                    return this.shapeList[t];
            return null
        },getFont: function(e) {
            var t = this.getTextStyle(r.clone(e));
            return t.fontStyle + " " + t.fontWeight + " " + t.fontSize + "px " + t.fontFamily
        },getTextStyle: function(e) {
            return r.merge(r.merge(e || {}, this.ecTheme.textStyle), i.textStyle)
        },getItemStyleColor: function(e, t, i, n) {
            return "function" == typeof e ? e.call(this.myChart, {seriesIndex: t,series: this.series[t],dataIndex: i,data: n}) : e
        },getDataFromOption: function(e, t) {
            return null != e ? null != e.value ? e.value : e : t
        },subPixelOptimize: function(e, t) {
            return e = t % 2 === 1 ? Math.floor(e) + .5 : Math.round(e)
        },resize: function() {
            this.refresh && this.refresh(), this.clearEffectShape && this.clearEffectShape(!0);
            var e = this;
            setTimeout(function() {
                e.animationEffect && e.animationEffect()
            }, 200)
        },clear: function() {
            this.clearEffectShape && this.clearEffectShape(), this.zr && this.zr.delShape(this.shapeList), this.shapeList = []
        },dispose: function() {
            this.onbeforDispose && this.onbeforDispose(), this.clear(), this.shapeList = null, this.effectList = null, this.messageCenter && this.messageCenter.unbind(i.EVENT.LEGEND_HOVERLINK, this._onlegendhoverlink), this.onafterDispose && this.onafterDispose()
        },query: a.query,deepQuery: a.deepQuery,deepMerge: a.deepMerge,parsePercent: o.parsePercent,parseCenter: o.parseCenter,parseRadius: o.parseRadius,numAddCommas: o.addCommas,getPrecision: o.getPrecision}, t
}), define("echarts/layout/EdgeBundling", ["require", "../data/KDTree", "zrender/tool/vector"], function(e) {
    function t(e, t) {
        e = e.array, t = t.array;
        var i = t[0] - e[0], n = t[1] - e[1], a = t[2] - e[2], o = t[3] - e[3];
        return i * i + n * n + a * a + o * o
    }
    function i(e) {
        this.points = [e.mp0, e.mp1], this.group = e
    }
    function n(e) {
        var t = e.points;
        t[0][1] < t[1][1] || e instanceof i ? (this.array = [t[0][0], t[0][1], t[1][0], t[1][1]], this._startPoint = t[0], this._endPoint = t[1]) : (this.array = [t[1][0], t[1][1], t[0][0], t[0][1]], this._startPoint = t[1], this._endPoint = t[0]), this.ink = d(t[0], t[1]), this.edge = e, this.group = null
    }
    function a() {
        this.edgeList = [], this.mp0 = l(), this.mp1 = l(), this.ink = 0
    }
    function o() {
        this.maxNearestEdge = 6, this.maxTurningAngle = Math.PI / 4, this.maxIteration = 20
    }
    var r = e("../data/KDTree"), s = e("zrender/tool/vector"), l = s.create, h = s.distSquare, d = s.dist, c = s.copy, m = s.clone;
    return n.prototype.getStartPoint = function() {
        return this._startPoint
    }, n.prototype.getEndPoint = function() {
        return this._endPoint
    }, a.prototype.addEdge = function(e) {
        e.group = this, this.edgeList.push(e)
    }, a.prototype.removeEdge = function(e) {
        e.group = null, this.edgeList.splice(this.edgeList.indexOf(e), 1)
    }, o.prototype = {constructor: o,run: function(e) {
            function t(e, t) {
                return h(e, t) < 1e-10
            }
            function n(e, i) {
                for (var n = [], a = 0, o = 0; o < e.length; o++)
                    a > 0 && t(e[o], n[a - 1]) || (n[a++] = m(e[o]));
                return i[0] && !t(n[0], i[0]) && (n = n.reverse()), n
            }
            for (var a = this._iterate(e), o = 0; o++ < this.maxIteration; ) {
                for (var r = [], s = 0; s < a.groups.length; s++)
                    r.push(new i(a.groups[s]));
                var l = this._iterate(r);
                if (l.savedInk <= 0)
                    break;
                a = l
            }
            var d = [], c = function(e, t) {
                for (var a, o = 0; o < e.length; o++) {
                    var r = e[o];
                    if (r.edgeList[0] && r.edgeList[0].edge instanceof i) {
                        for (var s = [], l = 0; l < r.edgeList.length; l++)
                            s.push(r.edgeList[l].edge.group);
                        a = t ? t.slice() : [], a.unshift(r.mp0), a.push(r.mp1), c(s, a)
                    } else
                        for (var l = 0; l < r.edgeList.length; l++) {
                            var h = r.edgeList[l];
                            a = t ? t.slice() : [], a.unshift(r.mp0), a.push(r.mp1), a.unshift(h.getStartPoint()), a.push(h.getEndPoint()), d.push({points: n(a, h.edge.points),rawEdge: h.edge})
                        }
                }
            };
            return c(a.groups), d
        },_iterate: function(e) {
            for (var i = [], o = [], s = 0, h = 0; h < e.length; h++) {
                var d = new n(e[h]);
                i.push(d)
            }
            for (var m = new r(i, 4), p = [], u = l(), V = l(), U = 0, g = l(), f = l(), y = 0, h = 0; h < i.length; h++) {
                var d = i[h];
                if (!d.group) {
                    m.nearestN(d, this.maxNearestEdge, t, p);
                    for (var b = 0, _ = null, x = null, k = 0; k < p.length; k++) {
                        var v = p[k], L = 0;
                        v.group ? v.group !== x && (x = v.group, U = this._calculateGroupEdgeInk(v.group, d, u, V), L = v.group.ink + d.ink - U) : (U = this._calculateEdgeEdgeInk(d, v, u, V), L = v.ink + d.ink - U), L > b && (b = L, _ = v, c(f, V), c(g, u), y = U)
                    }
                    if (_) {
                        s += b;
                        var w;
                        _.group || (w = new a, o.push(w), w.addEdge(_)), w = _.group, c(w.mp0, g), c(w.mp1, f), w.ink = y, _.group.addEdge(d)
                    } else {
                        var w = new a;
                        o.push(w), c(w.mp0, d.getStartPoint()), c(w.mp1, d.getEndPoint()), w.ink = d.ink, w.addEdge(d)
                    }
                }
            }
            return {groups: o,edges: i,savedInk: s}
        },_calculateEdgeEdgeInk: function() {
            var e = [], t = [];
            return function(i, n, a, o) {
                e[0] = i.getStartPoint(), e[1] = n.getStartPoint(), t[0] = i.getEndPoint(), t[1] = n.getEndPoint(), this._calculateMeetPoints(e, t, a, o);
                var r = d(e[0], a) + d(a, o) + d(o, t[0]) + d(e[1], a) + d(o, t[1]);
                return r
            }
        }(),_calculateGroupEdgeInk: function(e, t, i, n) {
            for (var a = [], o = [], r = 0; r < e.edgeList.length; r++) {
                var s = e.edgeList[r];
                a.push(s.getStartPoint()), o.push(s.getEndPoint())
            }
            a.push(t.getStartPoint()), o.push(t.getEndPoint()), this._calculateMeetPoints(a, o, i, n);
            for (var l = d(i, n), r = 0; r < a.length; r++)
                l += d(a[r], i) + d(o[r], n);
            return l
        },_calculateMeetPoints: function() {
            var e = l(), t = l();
            return function(i, n, a, o) {
                s.set(e, 0, 0), s.set(t, 0, 0);
                for (var r = i.length, l = 0; r > l; l++)
                    s.add(e, e, i[l]);
                s.scale(e, e, 1 / r), r = n.length;
                for (var l = 0; r > l; l++)
                    s.add(t, t, n[l]);
                s.scale(t, t, 1 / r), this._limitTurningAngle(i, e, t, a), this._limitTurningAngle(n, t, e, o)
            }
        }(),_limitTurningAngle: function() {
            var e = l(), t = l(), i = l(), n = l();
            return function(a, o, r, l) {
                var c = Math.cos(this.maxTurningAngle), m = Math.tan(this.maxTurningAngle);
                s.sub(e, o, r), s.normalize(e, e), s.copy(l, o);
                for (var p = 0, u = 0; u < a.length; u++) {
                    var V = a[u];
                    s.sub(t, V, o);
                    var U = s.len(t);
                    s.scale(t, t, 1 / U);
                    var g = s.dot(t, e);
                    if (c > g) {
                        s.scaleAndAdd(i, o, e, U * g);
                        var f = d(i, V), y = f / m;
                        s.scaleAndAdd(n, i, e, -y);
                        var b = h(n, o);
                        b > p && (p = b, s.copy(l, n))
                    }
                }
            }
        }()}, o
}), define("zrender/shape/Star", ["require", "../tool/math", "./Base", "../tool/util"], function(e) {
    var t = e("../tool/math"), i = t.sin, n = t.cos, a = Math.PI, o = e("./Base"), r = function(e) {
        o.call(this, e)
    };
    return r.prototype = {type: "star",buildPath: function(e, t) {
            var o = t.n;
            if (o && !(2 > o)) {
                var r = t.x, s = t.y, l = t.r, h = t.r0;
                null == h && (h = o > 4 ? l * n(2 * a / o) / n(a / o) : l / 3);
                var d = a / o, c = -a / 2, m = r + l * n(c), p = s + l * i(c);
                c += d;
                var u = t.pointList = [];
                u.push([m, p]);
                for (var V, U = 0, g = 2 * o - 1; g > U; U++)
                    V = U % 2 === 0 ? h : l, u.push([r + V * n(c), s + V * i(c)]), c += d;
                u.push([m, p]), e.moveTo(u[0][0], u[0][1]);
                for (var U = 0; U < u.length; U++)
                    e.lineTo(u[U][0], u[U][1]);
                e.closePath()
            }
        },getRect: function(e) {
            if (e.__rect)
                return e.__rect;
            var t;
            return t = "stroke" == e.brushType || "fill" == e.brushType ? e.lineWidth || 1 : 0, e.__rect = {x: Math.round(e.x - e.r - t / 2),y: Math.round(e.y - e.r - t / 2),width: 2 * e.r + t,height: 2 * e.r + t}, e.__rect
        }}, e("../tool/util").inherits(r, o), r
}), define("zrender/shape/Heart", ["require", "./Base", "./util/PathProxy", "../tool/area", "../tool/util"], function(e) {
    "use strict";
    var t = e("./Base"), i = e("./util/PathProxy"), n = e("../tool/area"), a = function(e) {
        t.call(this, e), this._pathProxy = new i
    };
    return a.prototype = {type: "heart",buildPath: function(e, t) {
            var n = this._pathProxy || new i;
            n.begin(e), n.moveTo(t.x, t.y), n.bezierCurveTo(t.x + t.a / 2, t.y - 2 * t.b / 3, t.x + 2 * t.a, t.y + t.b / 3, t.x, t.y + t.b), n.bezierCurveTo(t.x - 2 * t.a, t.y + t.b / 3, t.x - t.a / 2, t.y - 2 * t.b / 3, t.x, t.y), n.closePath()
        },getRect: function(e) {
            return e.__rect ? e.__rect : (this._pathProxy.isEmpty() || this.buildPath(null, e), this._pathProxy.fastBoundingRect())
        },isCover: function(e, t) {
            var i = this.transformCoordToLocal(e, t);
            return e = i[0], t = i[1], this.isCoverRect(e, t) ? n.isInsidePath(this._pathProxy.pathCommands, this.style.lineWidth, this.style.brushType, e, t) : void 0
        }}, e("../tool/util").inherits(a, t), a
}), define("zrender/shape/Droplet", ["require", "./Base", "./util/PathProxy", "../tool/area", "../tool/util"], function(e) {
    "use strict";
    var t = e("./Base"), i = e("./util/PathProxy"), n = e("../tool/area"), a = function(e) {
        t.call(this, e), this._pathProxy = new i
    };
    return a.prototype = {type: "droplet",buildPath: function(e, t) {
            var n = this._pathProxy || new i;
            n.begin(e), n.moveTo(t.x, t.y + t.a), n.bezierCurveTo(t.x + t.a, t.y + t.a, t.x + 3 * t.a / 2, t.y - t.a / 3, t.x, t.y - t.b), n.bezierCurveTo(t.x - 3 * t.a / 2, t.y - t.a / 3, t.x - t.a, t.y + t.a, t.x, t.y + t.a), n.closePath()
        },getRect: function(e) {
            return e.__rect ? e.__rect : (this._pathProxy.isEmpty() || this.buildPath(null, e), this._pathProxy.fastBoundingRect())
        },isCover: function(e, t) {
            var i = this.transformCoordToLocal(e, t);
            return e = i[0], t = i[1], this.isCoverRect(e, t) ? n.isInsidePath(this._pathProxy.pathCommands, this.style.lineWidth, this.style.brushType, e, t) : void 0
        }}, e("../tool/util").inherits(a, t), a
}), define("zrender/tool/math", [], function() {
    function e(e, t) {
        return Math.sin(t ? e * a : e)
    }
    function t(e, t) {
        return Math.cos(t ? e * a : e)
    }
    function i(e) {
        return e * a
    }
    function n(e) {
        return e / a
    }
    var a = Math.PI / 180;
    return {sin: e,cos: t,degreeToRadian: i,radianToDegree: n}
}), define("zrender/shape/util/PathProxy", ["require", "../../tool/vector"], function(e) {
    var t = e("../../tool/vector"), i = function(e, t) {
        this.command = e, this.points = t || null
    }, n = function() {
        this.pathCommands = [], this._ctx = null, this._min = [], this._max = []
    };
    return n.prototype.fastBoundingRect = function() {
        var e = this._min, i = this._max;
        e[0] = e[1] = 1 / 0, i[0] = i[1] = -(1 / 0);
        for (var n = 0; n < this.pathCommands.length; n++) {
            var a = this.pathCommands[n], o = a.points;
            switch (a.command) {
                case "M":
                    t.min(e, e, o), t.max(i, i, o);
                    break;
                case "L":
                    t.min(e, e, o), t.max(i, i, o);
                    break;
                case "C":
                    for (var r = 0; 6 > r; r += 2)
                        e[0] = Math.min(e[0], e[0], o[r]), e[1] = Math.min(e[1], e[1], o[r + 1]), i[0] = Math.max(i[0], i[0], o[r]), i[1] = Math.max(i[1], i[1], o[r + 1]);
                    break;
                case "Q":
                    for (var r = 0; 4 > r; r += 2)
                        e[0] = Math.min(e[0], e[0], o[r]), e[1] = Math.min(e[1], e[1], o[r + 1]), i[0] = Math.max(i[0], i[0], o[r]), i[1] = Math.max(i[1], i[1], o[r + 1]);
                    break;
                case "A":
                    var s = o[0], l = o[1], h = o[2], d = o[3];
                    e[0] = Math.min(e[0], e[0], s - h), e[1] = Math.min(e[1], e[1], l - d), i[0] = Math.max(i[0], i[0], s + h), i[1] = Math.max(i[1], i[1], l + d)
            }
        }
        return {x: e[0],y: e[1],width: i[0] - e[0],height: i[1] - e[1]}
    }, n.prototype.begin = function(e) {
        return this._ctx = e || null, this.pathCommands.length = 0, this
    }, n.prototype.moveTo = function(e, t) {
        return this.pathCommands.push(new i("M", [e, t])), this._ctx && this._ctx.moveTo(e, t), this
    }, n.prototype.lineTo = function(e, t) {
        return this.pathCommands.push(new i("L", [e, t])), this._ctx && this._ctx.lineTo(e, t), this
    }, n.prototype.bezierCurveTo = function(e, t, n, a, o, r) {
        return this.pathCommands.push(new i("C", [e, t, n, a, o, r])), this._ctx && this._ctx.bezierCurveTo(e, t, n, a, o, r), this
    }, n.prototype.quadraticCurveTo = function(e, t, n, a) {
        return this.pathCommands.push(new i("Q", [e, t, n, a])), this._ctx && this._ctx.quadraticCurveTo(e, t, n, a), this
    }, n.prototype.arc = function(e, t, n, a, o, r) {
        return this.pathCommands.push(new i("A", [e, t, n, n, a, o - a, 0, r ? 0 : 1])), this._ctx && this._ctx.arc(e, t, n, a, o, r), this
    }, n.prototype.arcTo = function(e, t, i, n, a) {
        return this._ctx && this._ctx.arcTo(e, t, i, n, a), this
    }, n.prototype.rect = function(e, t, i, n) {
        return this._ctx && this._ctx.rect(e, t, i, n), this
    }, n.prototype.closePath = function() {
        return this.pathCommands.push(new i("z")), this._ctx && this._ctx.closePath(), this
    }, n.prototype.isEmpty = function() {
        return 0 === this.pathCommands.length
    }, n.PathSegment = i, n
}), define("zrender/shape/Line", ["require", "./Base", "./util/dashedLineTo", "../tool/util"], function(e) {
    var t = e("./Base"), i = e("./util/dashedLineTo"), n = function(e) {
        this.brushTypeOnly = "stroke", this.textPosition = "end", t.call(this, e)
    };
    return n.prototype = {type: "line",buildPath: function(e, t) {
            if (t.lineType && "solid" != t.lineType) {
                if ("dashed" == t.lineType || "dotted" == t.lineType) {
                    var n = (t.lineWidth || 1) * ("dashed" == t.lineType ? 5 : 1);
                    i(e, t.xStart, t.yStart, t.xEnd, t.yEnd, n)
                }
            } else
                e.moveTo(t.xStart, t.yStart), e.lineTo(t.xEnd, t.yEnd)
        },getRect: function(e) {
            if (e.__rect)
                return e.__rect;
            var t = e.lineWidth || 1;
            return e.__rect = {x: Math.min(e.xStart, e.xEnd) - t,y: Math.min(e.yStart, e.yEnd) - t,width: Math.abs(e.xStart - e.xEnd) + t,height: Math.abs(e.yStart - e.yEnd) + t}, e.__rect
        }}, e("../tool/util").inherits(n, t), n
}), define("zrender/shape/BezierCurve", ["require", "./Base", "../tool/util"], function(e) {
    "use strict";
    var t = e("./Base"), i = function(e) {
        this.brushTypeOnly = "stroke", this.textPosition = "end", t.call(this, e)
    };
    return i.prototype = {type: "bezier-curve",buildPath: function(e, t) {
            e.moveTo(t.xStart, t.yStart), "undefined" != typeof t.cpX2 && "undefined" != typeof t.cpY2 ? e.bezierCurveTo(t.cpX1, t.cpY1, t.cpX2, t.cpY2, t.xEnd, t.yEnd) : e.quadraticCurveTo(t.cpX1, t.cpY1, t.xEnd, t.yEnd)
        },getRect: function(e) {
            if (e.__rect)
                return e.__rect;
            var t = Math.min(e.xStart, e.xEnd, e.cpX1), i = Math.min(e.yStart, e.yEnd, e.cpY1), n = Math.max(e.xStart, e.xEnd, e.cpX1), a = Math.max(e.yStart, e.yEnd, e.cpY1), o = e.cpX2, r = e.cpY2;
            "undefined" != typeof o && "undefined" != typeof r && (t = Math.min(t, o), i = Math.min(i, r), n = Math.max(n, o), a = Math.max(a, r));
            var s = e.lineWidth || 1;
            return e.__rect = {x: t - s,y: i - s,width: n - t + s,height: a - i + s}, e.__rect
        }}, e("../tool/util").inherits(i, t), i
}), define("zrender/shape/util/dashedLineTo", [], function() {
    var e = [5, 5];
    return function(t, i, n, a, o, r) {
        if (t.setLineDash)
            return e[0] = e[1] = r, t.setLineDash(e), t.moveTo(i, n), void t.lineTo(a, o);
        r = "number" != typeof r ? 5 : r;
        var s = a - i, l = o - n, h = Math.floor(Math.sqrt(s * s + l * l) / r);
        s /= h, l /= h;
        for (var d = !0, c = 0; h > c; ++c)
            d ? t.moveTo(i, n) : t.lineTo(i, n), d = !d, i += s, n += l;
        t.lineTo(a, o)
    }
}), define("zrender/shape/Polygon", ["require", "./Base", "./util/smoothSpline", "./util/smoothBezier", "./util/dashedLineTo", "../tool/util"], function(e) {
    var t = e("./Base"), i = e("./util/smoothSpline"), n = e("./util/smoothBezier"), a = e("./util/dashedLineTo"), o = function(e) {
        t.call(this, e)
    };
    return o.prototype = {type: "polygon",buildPath: function(e, t) {
            var o = t.pointList;
            if (!(o.length < 2)) {
                if (t.smooth && "spline" !== t.smooth) {
                    var r = n(o, t.smooth, !0, t.smoothConstraint);
                    e.moveTo(o[0][0], o[0][1]);
                    for (var s, l, h, d = o.length, c = 0; d > c; c++)
                        s = r[2 * c], l = r[2 * c + 1], h = o[(c + 1) % d], e.bezierCurveTo(s[0], s[1], l[0], l[1], h[0], h[1])
                } else if ("spline" === t.smooth && (o = i(o, !0)), t.lineType && "solid" != t.lineType) {
                    if ("dashed" == t.lineType || "dotted" == t.lineType) {
                        var m = t._dashLength || (t.lineWidth || 1) * ("dashed" == t.lineType ? 5 : 1);
                        t._dashLength = m, e.moveTo(o[0][0], o[0][1]);
                        for (var c = 1, p = o.length; p > c; c++)
                            a(e, o[c - 1][0], o[c - 1][1], o[c][0], o[c][1], m);
                        a(e, o[o.length - 1][0], o[o.length - 1][1], o[0][0], o[0][1], m)
                    }
                } else {
                    e.moveTo(o[0][0], o[0][1]);
                    for (var c = 1, p = o.length; p > c; c++)
                        e.lineTo(o[c][0], o[c][1]);
                    e.lineTo(o[0][0], o[0][1])
                }
                e.closePath()
            }
        },getRect: function(e) {
            if (e.__rect)
                return e.__rect;
            for (var t = Number.MAX_VALUE, i = Number.MIN_VALUE, n = Number.MAX_VALUE, a = Number.MIN_VALUE, o = e.pointList, r = 0, s = o.length; s > r; r++)
                o[r][0] < t && (t = o[r][0]), o[r][0] > i && (i = o[r][0]), o[r][1] < n && (n = o[r][1]), o[r][1] > a && (a = o[r][1]);
            var l;
            return l = "stroke" == e.brushType || "fill" == e.brushType ? e.lineWidth || 1 : 0, e.__rect = {x: Math.round(t - l / 2),y: Math.round(n - l / 2),width: i - t + l,height: a - n + l}, e.__rect
        }}, e("../tool/util").inherits(o, t), o
}), define("echarts/util/shape/normalIsCover", [], function() {
    return function(e, t) {
        var i = this.transformCoordToLocal(e, t);
        return e = i[0], t = i[1], this.isCoverRect(e, t)
    }
}), define("zrender/shape/util/smoothSpline", ["require", "../../tool/vector"], function(e) {
    function t(e, t, i, n, a, o, r) {
        var s = .5 * (i - e), l = .5 * (n - t);
        return (2 * (t - i) + s + l) * r + (-3 * (t - i) - 2 * s - l) * o + s * a + t
    }
    var i = e("../../tool/vector");
    return function(e, n) {
        for (var a = e.length, o = [], r = 0, s = 1; a > s; s++)
            r += i.distance(e[s - 1], e[s]);
        var l = r / 5;
        l = a > l ? a : l;
        for (var s = 0; l > s; s++) {
            var h, d, c, m = s / (l - 1) * (n ? a : a - 1), p = Math.floor(m), u = m - p, V = e[p % a];
            n ? (h = e[(p - 1 + a) % a], d = e[(p + 1) % a], c = e[(p + 2) % a]) : (h = e[0 === p ? p : p - 1], d = e[p > a - 2 ? a - 1 : p + 1], c = e[p > a - 3 ? a - 1 : p + 2]);
            var U = u * u, g = u * U;
            o.push([t(h[0], V[0], d[0], c[0], u, U, g), t(h[1], V[1], d[1], c[1], u, U, g)])
        }
        return o
    }
}), define("zrender/shape/util/smoothBezier", ["require", "../../tool/vector"], function(e) {
    var t = e("../../tool/vector");
    return function(e, i, n, a) {
        var o, r, s, l, h = [], d = [], c = [], m = [], p = !!a;
        if (p) {
            s = [1 / 0, 1 / 0], l = [-(1 / 0), -(1 / 0)];
            
            for (var u = 0, V = e.length; V > u; u++)
                t.min(s, s, e[u]), t.max(l, l, e[u]);
            t.min(s, s, a[0]), t.max(l, l, a[1])
        }
        for (var u = 0, V = e.length; V > u; u++) {
            var o, r, U = e[u];
            if (n)
                o = e[u ? u - 1 : V - 1], r = e[(u + 1) % V];
            else {
                if (0 === u || u === V - 1) {
                    h.push(t.clone(e[u]));
                    continue
                }
                o = e[u - 1], r = e[u + 1]
            }
            t.sub(d, r, o), t.scale(d, d, i);
            var g = t.distance(U, o), f = t.distance(U, r), y = g + f;
            0 !== y && (g /= y, f /= y), t.scale(c, d, -g), t.scale(m, d, f);
            var b = t.add([], U, c), _ = t.add([], U, m);
            p && (t.max(b, b, s), t.min(b, b, l), t.max(_, _, s), t.min(_, _, l)), h.push(b), h.push(_)
        }
        return n && h.push(t.clone(h.shift())), h
    }
}), define("echarts/util/ecQuery", ["require", "zrender/tool/util"], function(e) {
    function t(e, t) {
        if ("undefined" != typeof e) {
            if (!t)
                return e;
            t = t.split(".");
            for (var i = t.length, n = 0; i > n; ) {
                if (e = e[t[n]], "undefined" == typeof e)
                    return;
                n++
            }
            return e
        }
    }
    function i(e, i) {
        for (var n, a = 0, o = e.length; o > a; a++)
            if (n = t(e[a], i), "undefined" != typeof n)
                return n
    }
    function n(e, i) {
        for (var n, o = e.length; o--; ) {
            var r = t(e[o], i);
            "undefined" != typeof r && ("undefined" == typeof n ? n = a.clone(r) : a.merge(n, r, !0))
        }
        return n
    }
    var a = e("zrender/tool/util");
    return {query: t,deepQuery: i,deepMerge: n}
}), define("echarts/util/number", [], function() {
    function e(e) {
        return e.replace(/^\s+/, "").replace(/\s+$/, "")
    }
    function t(t, i) {
        return "string" == typeof t ? e(t).match(/%$/) ? parseFloat(t) / 100 * i : parseFloat(t) : t
    }
    function i(e, i) {
        return [t(i[0], e.getWidth()), t(i[1], e.getHeight())]
    }
    function n(e, i) {
        i instanceof Array || (i = [0, i]);
        var n = Math.min(e.getWidth(), e.getHeight()) / 2;
        return [t(i[0], n), t(i[1], n)]
    }
    function a(e) {
        return isNaN(e) ? "-" : (e = (e + "").split("."), e[0].replace(/(\d{1,3})(?=(?:\d{3})+(?!\d))/g, "$1,") + (e.length > 1 ? "." + e[1] : ""))
    }
    function o(e) {
        for (var t = 1, i = 0; Math.round(e * t) / t !== e; )
            t *= 10, i++;
        return i
    }
    return {parsePercent: t,parseCenter: i,parseRadius: n,addCommas: a,getPrecision: o}
}), define("echarts/data/KDTree", ["require", "./quickSelect"], function(e) {
    function t(e, t) {
        this.left = null, this.right = null, this.axis = e, this.data = t
    }
    var i = e("./quickSelect"), n = function(e, t) {
        e.length && (t || (t = e[0].array.length), this.dimension = t, this.root = this._buildTree(e, 0, e.length - 1, 0), this._stack = [], this._nearstNList = [])
    };
    return n.prototype._buildTree = function(e, n, a, o) {
        if (n > a)
            return null;
        var r = Math.floor((n + a) / 2);
        r = i(e, n, a, r, function(e, t) {
            return e.array[o] - t.array[o]
        });
        var s = e[r], l = new t(o, s);
        return o = (o + 1) % this.dimension, a > n && (l.left = this._buildTree(e, n, r - 1, o), l.right = this._buildTree(e, r + 1, a, o)), l
    }, n.prototype.nearest = function(e, t) {
        var i = this.root, n = this._stack, a = 0, o = 1 / 0, r = null;
        for (i.data !== e && (o = t(i.data, e), r = i), e.array[i.axis] < i.data.array[i.axis] ? (i.right && (n[a++] = i.right), i.left && (n[a++] = i.left)) : (i.left && (n[a++] = i.left), i.right && (n[a++] = i.right)); a--; ) {
            i = n[a];
            var s = e.array[i.axis] - i.data.array[i.axis], l = 0 > s, h = !1;
            s *= s, o > s && (s = t(i.data, e), o > s && i.data !== e && (o = s, r = i), h = !0), l ? (h && i.right && (n[a++] = i.right), i.left && (n[a++] = i.left)) : (h && i.left && (n[a++] = i.left), i.right && (n[a++] = i.right))
        }
        return r.data
    }, n.prototype._addNearest = function(e, t, i) {
        for (var n = this._nearstNList, a = e - 1; a > 0 && !(t >= n[a - 1].dist); a--)
            n[a].dist = n[a - 1].dist, n[a].node = n[a - 1].node;
        n[a].dist = t, n[a].node = i
    }, n.prototype.nearestN = function(e, t, i, n) {
        if (0 >= t)
            return n.length = 0, n;
        for (var a = this.root, o = this._stack, r = 0, s = this._nearstNList, l = 0; t > l; l++)
            s[l] || (s[l] = {}), s[l].dist = 0, s[l].node = null;
        var h = i(a.data, e), d = 0;
        for (a.data !== e && (d++, this._addNearest(d, h, a)), e.array[a.axis] < a.data.array[a.axis] ? (a.right && (o[r++] = a.right), a.left && (o[r++] = a.left)) : (a.left && (o[r++] = a.left), a.right && (o[r++] = a.right)); r--; ) {
            a = o[r];
            var h = e.array[a.axis] - a.data.array[a.axis], c = 0 > h, m = !1;
            h *= h, (t > d || h < s[d - 1].dist) && (h = i(a.data, e), (t > d || h < s[d - 1].dist) && a.data !== e && (t > d && d++, this._addNearest(d, h, a)), m = !0), c ? (m && a.right && (o[r++] = a.right), a.left && (o[r++] = a.left)) : (m && a.left && (o[r++] = a.left), a.right && (o[r++] = a.right))
        }
        for (var l = 0; d > l; l++)
            n[l] = s[l].node.data;
        return n.length = d, n
    }, n
}), define("echarts/data/quickSelect", ["require"], function() {
    function e(e, t) {
        return e - t
    }
    function t(e, t, i) {
        var n = e[t];
        e[t] = e[i], e[i] = n
    }
    function i(e, i, n, a, o) {
        for (var r = i; n > i; ) {
            var r = Math.round((n + i) / 2), s = e[r];
            t(e, r, n), r = i;
            for (var l = i; n - 1 >= l; l++)
                o(s, e[l]) >= 0 && (t(e, l, r), r++);
            if (t(e, n, r), r === a)
                return r;
            a > r ? i = r + 1 : n = r - 1
        }
        return i
    }
    function n(t, n, a, o, r) {
        return arguments.length <= 3 && (o = n, r = 2 == arguments.length ? e : a, n = 0, a = t.length - 1), i(t, n, a, o, r)
    }
    return n
}), define("echarts/component/dataView", ["require", "./base", "../config", "zrender/tool/util", "../component"], function(e) {
    function t(e, t, n, a, o) {
        i.call(this, e, t, n, a, o), this.dom = o.dom, this._tDom = document.createElement("div"), this._textArea = document.createElement("textArea"), this._buttonRefresh = document.createElement("button"), this._buttonRefresh.setAttribute("type", "button"), this._buttonClose = document.createElement("button"), this._buttonClose.setAttribute("type", "button"), this._hasShow = !1, this._zrHeight = n.getHeight(), this._zrWidth = n.getWidth(), this._tDom.className = "echarts-dataview", this.hide(), this.dom.firstChild.appendChild(this._tDom), window.addEventListener ? (this._tDom.addEventListener("click", this._stop), this._tDom.addEventListener("mousewheel", this._stop), this._tDom.addEventListener("mousemove", this._stop), this._tDom.addEventListener("mousedown", this._stop), this._tDom.addEventListener("mouseup", this._stop), this._tDom.addEventListener("touchstart", this._stop), this._tDom.addEventListener("touchmove", this._stop), this._tDom.addEventListener("touchend", this._stop)) : (this._tDom.attachEvent("onclick", this._stop), this._tDom.attachEvent("onmousewheel", this._stop), this._tDom.attachEvent("onmousemove", this._stop), this._tDom.attachEvent("onmousedown", this._stop), this._tDom.attachEvent("onmouseup", this._stop))
    }
    var i = e("./base"), n = e("../config"), a = e("zrender/tool/util");
    return t.prototype = {type: n.COMPONENT_TYPE_DATAVIEW,_lang: ["Data View", "close", "refresh"],_gCssText: "position:absolute;display:block;overflow:hidden;transition:height 0.8s,background-color 1s;-moz-transition:height 0.8s,background-color 1s;-webkit-transition:height 0.8s,background-color 1s;-o-transition:height 0.8s,background-color 1s;z-index:1;left:0;top:0;",hide: function() {
            this._sizeCssText = "width:" + this._zrWidth + "px;height:0px;background-color:#f0ffff;", this._tDom.style.cssText = this._gCssText + this._sizeCssText
        },show: function(e) {
            this._hasShow = !0;
            var t = this.query(this.option, "toolbox.feature.dataView.lang") || this._lang;
            this.option = e, this._tDom.innerHTML = '<p style="padding:8px 0;margin:0 0 10px 0;border-bottom:1px solid #eee">' + (t[0] || this._lang[0]) + "</p>";
            var i = this.query(this.option, "toolbox.feature.dataView.optionToContent");
            "function" != typeof i ? this._textArea.value = this._optionToContent() : (this._textArea = document.createElement("div"), this._textArea.innerHTML = i(this.option)), this._textArea.style.cssText = "display:block;margin:0 0 8px 0;padding:4px 6px;overflow:auto;width:100%;height:" + (this._zrHeight - 100) + "px;", this._tDom.appendChild(this._textArea), this._buttonClose.style.cssText = "float:right;padding:1px 6px;", this._buttonClose.innerHTML = t[1] || this._lang[1];
            var n = this;
            this._buttonClose.onclick = function() {
                n.hide()
            }, this._tDom.appendChild(this._buttonClose), this.query(this.option, "toolbox.feature.dataView.readOnly") === !1 ? (this._buttonRefresh.style.cssText = "float:right;margin-right:10px;padding:1px 6px;", this._buttonRefresh.innerHTML = t[2] || this._lang[2], this._buttonRefresh.onclick = function() {
                n._save()
            }, this._textArea.readOnly = !1, this._textArea.style.cursor = "default") : (this._buttonRefresh.style.cssText = "display:none", this._textArea.readOnly = !0, this._textArea.style.cursor = "text"), this._tDom.appendChild(this._buttonRefresh), this._sizeCssText = "width:" + this._zrWidth + "px;height:" + this._zrHeight + "px;background-color:#fff;", this._tDom.style.cssText = this._gCssText + this._sizeCssText
        },_optionToContent: function() {
            var e, t, i, a, o, r, s = [], l = "";
            if (this.option.xAxis)
                for (s = this.option.xAxis instanceof Array ? this.option.xAxis : [this.option.xAxis], e = 0, a = s.length; a > e; e++)
                    if ("category" == (s[e].type || "category")) {
                        for (r = [], t = 0, i = s[e].data.length; i > t; t++)
                            r.push(this.getDataFromOption(s[e].data[t]));
                        l += r.join(", ") + "\n\n"
                    }
            if (this.option.yAxis)
                for (s = this.option.yAxis instanceof Array ? this.option.yAxis : [this.option.yAxis], e = 0, a = s.length; a > e; e++)
                    if ("category" == s[e].type) {
                        for (r = [], t = 0, i = s[e].data.length; i > t; t++)
                            r.push(this.getDataFromOption(s[e].data[t]));
                        l += r.join(", ") + "\n\n"
                    }
            var h, d = this.option.series;
            for (e = 0, a = d.length; a > e; e++) {
                for (r = [], t = 0, i = d[e].data.length; i > t; t++)
                    o = d[e].data[t], h = d[e].type == n.CHART_TYPE_PIE || d[e].type == n.CHART_TYPE_MAP ? (o.name || "-") + ":" : "", d[e].type == n.CHART_TYPE_SCATTER && (o = this.getDataFromOption(o).join(", ")), r.push(h + this.getDataFromOption(o));
                l += (d[e].name || "-") + " : \n", l += r.join(d[e].type == n.CHART_TYPE_SCATTER ? "\n" : ", "), l += "\n\n"
            }
            return l
        },_save: function() {
            var e = this.query(this.option, "toolbox.feature.dataView.contentToOption");
            if ("function" != typeof e) {
                for (var t = this._textArea.value.split("\n"), i = [], a = 0, o = t.length; o > a; a++)
                    t[a] = this._trim(t[a]), "" !== t[a] && i.push(t[a]);
                this._contentToOption(i)
            } else
                e(this._textArea, this.option);
            this.hide();
            var r = this;
            setTimeout(function() {
                r.messageCenter && r.messageCenter.dispatch(n.EVENT.DATA_VIEW_CHANGED, null, {option: r.option}, r.myChart)
            }, r.canvasSupported ? 800 : 100)
        },_contentToOption: function(e) {
            var t, i, a, o, r, s, l, h = [], d = 0;
            if (this.option.xAxis)
                for (h = this.option.xAxis instanceof Array ? this.option.xAxis : [this.option.xAxis], t = 0, o = h.length; o > t; t++)
                    if ("category" == (h[t].type || "category")) {
                        for (s = e[d].split(","), i = 0, a = h[t].data.length; a > i; i++)
                            l = this._trim(s[i] || ""), r = h[t].data[i], "undefined" != typeof h[t].data[i].value ? h[t].data[i].value = l : h[t].data[i] = l;
                        d++
                    }
            if (this.option.yAxis)
                for (h = this.option.yAxis instanceof Array ? this.option.yAxis : [this.option.yAxis], t = 0, o = h.length; o > t; t++)
                    if ("category" == h[t].type) {
                        for (s = e[d].split(","), i = 0, a = h[t].data.length; a > i; i++)
                            l = this._trim(s[i] || ""), r = h[t].data[i], "undefined" != typeof h[t].data[i].value ? h[t].data[i].value = l : h[t].data[i] = l;
                        d++
                    }
            var c = this.option.series;
            for (t = 0, o = c.length; o > t; t++)
                if (d++, c[t].type == n.CHART_TYPE_SCATTER)
                    for (var i = 0, a = c[t].data.length; a > i; i++)
                        s = e[d], l = s.replace(" ", "").split(","), "undefined" != typeof c[t].data[i].value ? c[t].data[i].value = l : c[t].data[i] = l, d++;
                else {
                    s = e[d].split(",");
                    for (var i = 0, a = c[t].data.length; a > i; i++)
                        l = (s[i] || "").replace(/.*:/, ""), l = this._trim(l), l = "-" != l && "" !== l ? l - 0 : "-", "undefined" != typeof c[t].data[i].value ? c[t].data[i].value = l : c[t].data[i] = l;
                    d++
                }
        },_trim: function(e) {
            var t = new RegExp("(^[\\s\\t\\xa0\\u3000]+)|([\\u3000\\xa0\\s\\t]+$)", "g");
            return e.replace(t, "")
        },_stop: function(e) {
            e = e || window.event, e.stopPropagation ? e.stopPropagation() : e.cancelBubble = !0
        },resize: function() {
            this._zrHeight = this.zr.getHeight(), this._zrWidth = this.zr.getWidth(), this._tDom.offsetHeight > 10 && (this._sizeCssText = "width:" + this._zrWidth + "px;height:" + this._zrHeight + "px;background-color:#fff;", this._tDom.style.cssText = this._gCssText + this._sizeCssText, this._textArea.style.cssText = "display:block;margin:0 0 8px 0;padding:4px 6px;overflow:auto;width:100%;height:" + (this._zrHeight - 100) + "px;")
        },dispose: function() {
            window.removeEventListener ? (this._tDom.removeEventListener("click", this._stop), this._tDom.removeEventListener("mousewheel", this._stop), this._tDom.removeEventListener("mousemove", this._stop), this._tDom.removeEventListener("mousedown", this._stop), this._tDom.removeEventListener("mouseup", this._stop), this._tDom.removeEventListener("touchstart", this._stop), this._tDom.removeEventListener("touchmove", this._stop), this._tDom.removeEventListener("touchend", this._stop)) : (this._tDom.detachEvent("onclick", this._stop), this._tDom.detachEvent("onmousewheel", this._stop), this._tDom.detachEvent("onmousemove", this._stop), this._tDom.detachEvent("onmousedown", this._stop), this._tDom.detachEvent("onmouseup", this._stop)), this._buttonRefresh.onclick = null, this._buttonClose.onclick = null, this._hasShow && (this._tDom.removeChild(this._textArea), this._tDom.removeChild(this._buttonRefresh), this._tDom.removeChild(this._buttonClose)), this._textArea = null, this._buttonRefresh = null, this._buttonClose = null, this.dom.firstChild.removeChild(this._tDom), this._tDom = null
        }}, a.inherits(t, i), e("../component").define("dataView", t), t
}), define("echarts/util/shape/Cross", ["require", "zrender/shape/Base", "zrender/shape/Line", "zrender/tool/util", "./normalIsCover"], function(e) {
    function t(e) {
        i.call(this, e)
    }
    var i = e("zrender/shape/Base"), n = e("zrender/shape/Line"), a = e("zrender/tool/util");
    return t.prototype = {type: "cross",buildPath: function(e, t) {
            var i = t.rect;
            t.xStart = i.x, t.xEnd = i.x + i.width, t.yStart = t.yEnd = t.y, n.prototype.buildPath(e, t), t.xStart = t.xEnd = t.x, t.yStart = i.y, t.yEnd = i.y + i.height, n.prototype.buildPath(e, t)
        },getRect: function(e) {
            return e.rect
        },isCover: e("./normalIsCover")}, a.inherits(t, i), t
}), define("zrender/shape/Sector", ["require", "../tool/math", "../tool/computeBoundingBox", "../tool/vector", "./Base", "../tool/util"], function(e) {
    var t = e("../tool/math"), i = e("../tool/computeBoundingBox"), n = e("../tool/vector"), a = e("./Base"), o = n.create(), r = n.create(), s = n.create(), l = n.create(), h = function(e) {
        a.call(this, e)
    };
    return h.prototype = {type: "sector",buildPath: function(e, i) {
            var n = i.x, a = i.y, o = i.r0 || 0, r = i.r, s = i.startAngle, l = i.endAngle, h = i.clockWise || !1;
            s = t.degreeToRadian(s), l = t.degreeToRadian(l), h || (s = -s, l = -l);
            var d = t.cos(s), c = t.sin(s);
            e.moveTo(d * o + n, c * o + a), e.lineTo(d * r + n, c * r + a), e.arc(n, a, r, s, l, !h), e.lineTo(t.cos(l) * o + n, t.sin(l) * o + a), 0 !== o && e.arc(n, a, o, l, s, h), e.closePath()
        },getRect: function(e) {
            if (e.__rect)
                return e.__rect;
            var a = e.x, h = e.y, d = e.r0 || 0, c = e.r, m = t.degreeToRadian(e.startAngle), p = t.degreeToRadian(e.endAngle), u = e.clockWise;
            return u || (m = -m, p = -p), d > 1 ? i.arc(a, h, d, m, p, !u, o, s) : (o[0] = s[0] = a, o[1] = s[1] = h), i.arc(a, h, c, m, p, !u, r, l), n.min(o, o, r), n.max(s, s, l), e.__rect = {x: o[0],y: o[1],width: s[0] - o[0],height: s[1] - o[1]}, e.__rect
        }}, e("../tool/util").inherits(h, a), h
}), define("echarts/util/shape/Candle", ["require", "zrender/shape/Base", "zrender/tool/util", "./normalIsCover"], function(e) {
    function t(e) {
        i.call(this, e)
    }
    var i = e("zrender/shape/Base"), n = e("zrender/tool/util");
    return t.prototype = {type: "candle",_numberOrder: function(e, t) {
            return t - e
        },buildPath: function(e, t) {
            var i = n.clone(t.y).sort(this._numberOrder);
            e.moveTo(t.x, i[3]), e.lineTo(t.x, i[2]), e.moveTo(t.x - t.width / 2, i[2]), e.rect(t.x - t.width / 2, i[2], t.width, i[1] - i[2]), e.moveTo(t.x, i[1]), e.lineTo(t.x, i[0])
        },getRect: function(e) {
            if (!e.__rect) {
                var t = 0;
                ("stroke" == e.brushType || "fill" == e.brushType) && (t = e.lineWidth || 1);
                var i = n.clone(e.y).sort(this._numberOrder);
                e.__rect = {x: Math.round(e.x - e.width / 2 - t / 2),y: Math.round(i[3] - t / 2),width: e.width + t,height: i[0] - i[3] + t}
            }
            return e.__rect
        },isCover: e("./normalIsCover")}, n.inherits(t, i), t
}), define("zrender/tool/computeBoundingBox", ["require", "./vector", "./curve"], function(e) {
    function t(e, t, i) {
        if (0 !== e.length) {
            for (var n = e[0][0], a = e[0][0], o = e[0][1], r = e[0][1], s = 1; s < e.length; s++) {
                var l = e[s];
                l[0] < n && (n = l[0]), l[0] > a && (a = l[0]), l[1] < o && (o = l[1]), l[1] > r && (r = l[1])
            }
            t[0] = n, t[1] = o, i[0] = a, i[1] = r
        }
    }
    function i(e, t, i, n, a, r) {
        var s = [];
        o.cubicExtrema(e[0], t[0], i[0], n[0], s);
        for (var l = 0; l < s.length; l++)
            s[l] = o.cubicAt(e[0], t[0], i[0], n[0], s[l]);
        var h = [];
        o.cubicExtrema(e[1], t[1], i[1], n[1], h);
        for (var l = 0; l < h.length; l++)
            h[l] = o.cubicAt(e[1], t[1], i[1], n[1], h[l]);
        s.push(e[0], n[0]), h.push(e[1], n[1]);
        var d = Math.min.apply(null, s), c = Math.max.apply(null, s), m = Math.min.apply(null, h), p = Math.max.apply(null, h);
        a[0] = d, a[1] = m, r[0] = c, r[1] = p
    }
    function n(e, t, i, n, a) {
        var r = o.quadraticExtremum(e[0], t[0], i[0]), s = o.quadraticExtremum(e[1], t[1], i[1]);
        r = Math.max(Math.min(r, 1), 0), s = Math.max(Math.min(s, 1), 0);
        var l = 1 - r, h = 1 - s, d = l * l * e[0] + 2 * l * r * t[0] + r * r * i[0], c = l * l * e[1] + 2 * l * r * t[1] + r * r * i[1], m = h * h * e[0] + 2 * h * s * t[0] + s * s * i[0], p = h * h * e[1] + 2 * h * s * t[1] + s * s * i[1];
        n[0] = Math.min(e[0], i[0], d, m), n[1] = Math.min(e[1], i[1], c, p), a[0] = Math.max(e[0], i[0], d, m), a[1] = Math.max(e[1], i[1], c, p)
    }
    var a = e("./vector"), o = e("./curve"), r = a.create(), s = a.create(), l = a.create(), h = function(e, t, i, n, o, h, d, c) {
        if (Math.abs(n - o) >= 2 * Math.PI)
            return d[0] = e - i, d[1] = t - i, c[0] = e + i, void (c[1] = t + i);
        if (r[0] = Math.cos(n) * i + e, r[1] = Math.sin(n) * i + t, s[0] = Math.cos(o) * i + e, s[1] = Math.sin(o) * i + t, a.min(d, r, s), a.max(c, r, s), n %= 2 * Math.PI, 0 > n && (n += 2 * Math.PI), o %= 2 * Math.PI, 0 > o && (o += 2 * Math.PI), n > o && !h ? o += 2 * Math.PI : o > n && h && (n += 2 * Math.PI), h) {
            var m = o;
            o = n, n = m
        }
        for (var p = 0; o > p; p += Math.PI / 2)
            p > n && (l[0] = Math.cos(p) * i + e, l[1] = Math.sin(p) * i + t, a.min(d, l, d), a.max(c, l, c))
    };
    return t.cubeBezier = i, t.quadraticBezier = n, t.arc = h, t
}), define("echarts/util/shape/Chain", ["require", "zrender/shape/Base", "./Icon", "zrender/shape/util/dashedLineTo", "zrender/tool/util", "zrender/tool/matrix"], function(e) {
    function t(e) {
        i.call(this, e)
    }
    var i = e("zrender/shape/Base"), n = e("./Icon"), a = e("zrender/shape/util/dashedLineTo"), o = e("zrender/tool/util"), r = e("zrender/tool/matrix");
    return t.prototype = {type: "chain",brush: function(e, t) {
            var i = this.style;
            t && (i = this.getHighlightStyle(i, this.highlightStyle || {})), e.save(), this.setContext(e, i), this.setTransform(e), e.save(), e.beginPath(), this.buildLinePath(e, i), e.stroke(), e.restore(), this.brushSymbol(e, i), e.restore()
        },buildLinePath: function(e, t) {
            var i = t.x, n = t.y + 5, o = t.width, r = t.height / 2 - 10;
            if (e.moveTo(i, n), e.lineTo(i, n + r), e.moveTo(i + o, n), e.lineTo(i + o, n + r), e.moveTo(i, n + r / 2), t.lineType && "solid" != t.lineType) {
                if ("dashed" == t.lineType || "dotted" == t.lineType) {
                    var s = (t.lineWidth || 1) * ("dashed" == t.lineType ? 5 : 1);
                    a(e, i, n + r / 2, i + o, n + r / 2, s)
                }
            } else
                e.lineTo(i + o, n + r / 2)
        },brushSymbol: function(e, t) {
            var i = t.y + t.height / 4;
            e.save();
            for (var a, o = t.chainPoint, r = 0, s = o.length; s > r; r++) {
                if (a = o[r], "none" != a.symbol) {
                    e.beginPath();
                    var l = a.symbolSize;
                    n.prototype.buildPath(e, {iconType: a.symbol,x: a.x - l,y: i - l,width: 2 * l,height: 2 * l,n: a.n}), e.fillStyle = a.isEmpty ? "#fff" : t.strokeColor, e.closePath(), e.fill(), e.stroke()
                }
                a.showLabel && (e.font = a.textFont, e.fillStyle = a.textColor, e.textAlign = a.textAlign, e.textBaseline = a.textBaseline, a.rotation ? (e.save(), this._updateTextTransform(e, a.rotation), e.fillText(a.name, a.textX, a.textY), e.restore()) : e.fillText(a.name, a.textX, a.textY))
            }
            e.restore()
        },_updateTextTransform: function(e, t) {
            var i = r.create();
            if (r.identity(i), 0 !== t[0]) {
                var n = t[1] || 0, a = t[2] || 0;
                (n || a) && r.translate(i, i, [-n, -a]), r.rotate(i, i, t[0]), (n || a) && r.translate(i, i, [n, a])
            }
            e.transform.apply(e, i)
        },isCover: function(e, t) {
            var i = this.style;
            return e >= i.x && e <= i.x + i.width && t >= i.y && t <= i.y + i.height ? !0 : !1
        }}, o.inherits(t, i), t
}), define("zrender/shape/Ring", ["require", "./Base", "../tool/util"], function(e) {
    var t = e("./Base"), i = function(e) {
        t.call(this, e)
    };
    return i.prototype = {type: "ring",buildPath: function(e, t) {
            e.arc(t.x, t.y, t.r, 0, 2 * Math.PI, !1), e.moveTo(t.x + t.r0, t.y), e.arc(t.x, t.y, t.r0, 0, 2 * Math.PI, !0)
        },getRect: function(e) {
            if (e.__rect)
                return e.__rect;
            var t;
            return t = "stroke" == e.brushType || "fill" == e.brushType ? e.lineWidth || 1 : 0, e.__rect = {x: Math.round(e.x - e.r - t / 2),y: Math.round(e.y - e.r - t / 2),width: 2 * e.r + t,height: 2 * e.r + t}, e.__rect
        }}, e("../tool/util").inherits(i, t), i
}), define("echarts/component/axis", ["require", "./base", "zrender/shape/Line", "../config", "../util/ecData", "zrender/tool/util", "zrender/tool/color", "./categoryAxis", "./valueAxis", "../component"], function(e) {
    function t(e, t, n, a, o, r) {
        i.call(this, e, t, n, a, o), this.axisType = r, this._axisList = [], this.refresh(a)
    }
    var i = e("./base"), n = e("zrender/shape/Line"), a = e("../config"), o = e("../util/ecData"), r = e("zrender/tool/util"), s = e("zrender/tool/color");
    return t.prototype = {type: a.COMPONENT_TYPE_AXIS,axisBase: {_buildAxisLine: function() {
                var e = this.option.axisLine.lineStyle.width, t = e / 2, i = {_axisShape: "axisLine",zlevel: this.getZlevelBase(),z: this.getZBase() + 3,hoverable: !1}, a = this.grid;
                switch (this.option.position) {
                    case "left":
                        i.style = {xStart: a.getX() - t,yStart: a.getYend(),xEnd: a.getX() - t,yEnd: a.getY(),lineCap: "round"};
                        break;
                    case "right":
                        i.style = {xStart: a.getXend() + t,yStart: a.getYend(),xEnd: a.getXend() + t,yEnd: a.getY(),lineCap: "round"};
                        break;
                    case "bottom":
                        i.style = {xStart: a.getX(),yStart: a.getYend() + t,xEnd: a.getXend(),yEnd: a.getYend() + t,lineCap: "round"};
                        break;
                    case "top":
                        i.style = {xStart: a.getX(),yStart: a.getY() - t,xEnd: a.getXend(),yEnd: a.getY() - t,lineCap: "round"}
                }
                var o = i.style;
                "" !== this.option.name && (o.text = this.option.name, o.textPosition = this.option.nameLocation, o.textFont = this.getFont(this.option.nameTextStyle), this.option.nameTextStyle.align && (o.textAlign = this.option.nameTextStyle.align), this.option.nameTextStyle.baseline && (o.textBaseline = this.option.nameTextStyle.baseline), this.option.nameTextStyle.color && (o.textColor = this.option.nameTextStyle.color)), o.strokeColor = this.option.axisLine.lineStyle.color, o.lineWidth = e, this.isHorizontal() ? o.yStart = o.yEnd = this.subPixelOptimize(o.yEnd, e) : o.xStart = o.xEnd = this.subPixelOptimize(o.xEnd, e), o.lineType = this.option.axisLine.lineStyle.type, i = new n(i), this.shapeList.push(i)
            },_axisLabelClickable: function(e, t) {
                return e ? (o.pack(t, void 0, -1, void 0, -1, t.style.text), t.hoverable = !0, t.clickable = !0, t.highlightStyle = {color: s.lift(t.style.color, 1),brushType: "fill"}, t) : t
            },refixAxisShape: function(e, t) {
                if (this.option.axisLine.onZero) {
                    var i;
                    if (this.isHorizontal() && null != t)
                        for (var n = 0, a = this.shapeList.length; a > n; n++)
                            "axisLine" === this.shapeList[n]._axisShape ? (this.shapeList[n].style.yStart = this.shapeList[n].style.yEnd = this.subPixelOptimize(t, this.shapeList[n].stylelineWidth), this.zr.modShape(this.shapeList[n].id)) : "axisTick" === this.shapeList[n]._axisShape && (i = this.shapeList[n].style.yEnd - this.shapeList[n].style.yStart, this.shapeList[n].style.yStart = t - i, this.shapeList[n].style.yEnd = t, this.zr.modShape(this.shapeList[n].id));
                    if (!this.isHorizontal() && null != e)
                        for (var n = 0, a = this.shapeList.length; a > n; n++)
                            "axisLine" === this.shapeList[n]._axisShape ? (this.shapeList[n].style.xStart = this.shapeList[n].style.xEnd = this.subPixelOptimize(e, this.shapeList[n].stylelineWidth), this.zr.modShape(this.shapeList[n].id)) : "axisTick" === this.shapeList[n]._axisShape && (i = this.shapeList[n].style.xEnd - this.shapeList[n].style.xStart, this.shapeList[n].style.xStart = e, this.shapeList[n].style.xEnd = e + i, this.zr.modShape(this.shapeList[n].id))
                }
            },getPosition: function() {
                return this.option.position
            },isHorizontal: function() {
                return "bottom" === this.option.position || "top" === this.option.position
            }},reformOption: function(e) {
            if (!e || e instanceof Array && 0 === e.length ? e = [{type: a.COMPONENT_TYPE_AXIS_VALUE}] : e instanceof Array || (e = [e]), e.length > 2 && (e = [e[0], e[1]]), "xAxis" === this.axisType) {
                (!e[0].position || "bottom" != e[0].position && "top" != e[0].position) && (e[0].position = "bottom"), e.length > 1 && (e[1].position = "bottom" === e[0].position ? "top" : "bottom");
                for (var t = 0, i = e.length; i > t; t++)
                    e[t].type = e[t].type || "category", e[t].xAxisIndex = t, e[t].yAxisIndex = -1
            } else {
                (!e[0].position || "left" != e[0].position && "right" != e[0].position) && (e[0].position = "left"), e.length > 1 && (e[1].position = "left" === e[0].position ? "right" : "left");
                for (var t = 0, i = e.length; i > t; t++)
                    e[t].type = e[t].type || "value", e[t].xAxisIndex = -1, e[t].yAxisIndex = t
            }
            return e
        },refresh: function(t) {
            var i;
            t && (this.option = t, "xAxis" === this.axisType ? (this.option.xAxis = this.reformOption(t.xAxis), i = this.option.xAxis) : (this.option.yAxis = this.reformOption(t.yAxis), i = this.option.yAxis), this.series = t.series);
            for (var n = e("./categoryAxis"), a = e("./valueAxis"), o = Math.max(i && i.length || 0, this._axisList.length), r = 0; o > r; r++)
                !this._axisList[r] || !t || i[r] && this._axisList[r].type == i[r].type || (this._axisList[r].dispose && this._axisList[r].dispose(), this._axisList[r] = !1), this._axisList[r] ? this._axisList[r].refresh && this._axisList[r].refresh(i ? i[r] : !1, this.series) : i && i[r] && (this._axisList[r] = "category" === i[r].type ? new n(this.ecTheme, this.messageCenter, this.zr, i[r], this.myChart, this.axisBase) : new a(this.ecTheme, this.messageCenter, this.zr, i[r], this.myChart, this.axisBase, this.series))
        },getAxis: function(e) {
            return this._axisList[e]
        },getAxisCount: function() {
            return this._axisList.length
        },clear: function() {
            for (var e = 0, t = this._axisList.length; t > e; e++)
                this._axisList[e].dispose && this._axisList[e].dispose();
            this._axisList = []
        }}, r.inherits(t, i), e("../component").define("axis", t), t
}), define("echarts/component/grid", ["require", "./base", "zrender/shape/Rectangle", "../config", "zrender/tool/util", "../component"], function(e) {
    function t(e, t, n, a, o) {
        i.call(this, e, t, n, a, o), this.refresh(a)
    }
    var i = e("./base"), n = e("zrender/shape/Rectangle"), a = e("../config");
    a.grid = {zlevel: 0,z: 0,x: 80,y: 60,x2: 80,y2: 60,backgroundColor: "rgba(0,0,0,0)",borderWidth: 1,borderColor: "#ccc"};
    var o = e("zrender/tool/util");
    return t.prototype = {type: a.COMPONENT_TYPE_GRID,getX: function() {
            return this._x
        },getY: function() {
            return this._y
        },getWidth: function() {
            return this._width
        },getHeight: function() {
            return this._height
        },getXend: function() {
            return this._x + this._width
        },getYend: function() {
            return this._y + this._height
        },getArea: function() {
            return {x: this._x,y: this._y,width: this._width,height: this._height}
        },getBbox: function() {
            return [[this._x, this._y], [this.getXend(), this.getYend()]]
        },refixAxisShape: function(e) {
            for (var t, i, n, o = e.xAxis._axisList.concat(e.yAxis ? e.yAxis._axisList : []), r = o.length; r--; )
                n = o[r], n.type == a.COMPONENT_TYPE_AXIS_VALUE && n._min < 0 && n._max >= 0 && (n.isHorizontal() ? t = n.getCoord(0) : i = n.getCoord(0));
            if ("undefined" != typeof t || "undefined" != typeof i)
                for (r = o.length; r--; )
                    o[r].refixAxisShape(t, i)
        },refresh: function(e) {
            if (e || this._zrWidth != this.zr.getWidth() || this._zrHeight != this.zr.getHeight()) {
                this.clear(), this.option = e || this.option, this.option.grid = this.reformOption(this.option.grid);
                var t = this.option.grid;
                this._zrWidth = this.zr.getWidth(), this._zrHeight = this.zr.getHeight(), this._x = this.parsePercent(t.x, this._zrWidth), this._y = this.parsePercent(t.y, this._zrHeight);
                var i = this.parsePercent(t.x2, this._zrWidth), a = this.parsePercent(t.y2, this._zrHeight);
                this._width = "undefined" == typeof t.width ? this._zrWidth - this._x - i : this.parsePercent(t.width, this._zrWidth), this._width = this._width <= 0 ? 10 : this._width, this._height = "undefined" == typeof t.height ? this._zrHeight - this._y - a : this.parsePercent(t.height, this._zrHeight), this._height = this._height <= 0 ? 10 : this._height, this._x = this.subPixelOptimize(this._x, t.borderWidth), this._y = this.subPixelOptimize(this._y, t.borderWidth), this.shapeList.push(new n({zlevel: this.getZlevelBase(),z: this.getZBase(),hoverable: !1,style: {x: this._x,y: this._y,width: this._width,height: this._height,brushType: t.borderWidth > 0 ? "both" : "fill",color: t.backgroundColor,strokeColor: t.borderColor,lineWidth: t.borderWidth}})), this.zr.addShape(this.shapeList[0])
            }
        }}, o.inherits(t, i), e("../component").define("grid", t), t
}), define("echarts/component/dataZoom", ["require", "./base", "zrender/shape/Rectangle", "zrender/shape/Polygon", "../util/shape/Icon", "../config", "../util/date", "zrender/tool/util", "../component"], function(e) {
    function t(e, t, n, a, o) {
        i.call(this, e, t, n, a, o);
        var r = this;
        r._ondrift = function(e, t) {
            return r.__ondrift(this, e, t)
        }, r._ondragend = function() {
            return r.__ondragend()
        }, this._fillerSize = 30, this._isSilence = !1, this._zoom = {}, this.option.dataZoom = this.reformOption(this.option.dataZoom), this.zoomOption = this.option.dataZoom, this._handleSize = this.zoomOption.handleSize, this.myChart.canvasSupported || (this.zoomOption.realtime = !1), this._location = this._getLocation(), this._zoom = this._getZoom(), this._backupData(), this.option.dataZoom.show && this._buildShape(), this._syncData()
    }
    var i = e("./base"), n = e("zrender/shape/Rectangle"), a = e("zrender/shape/Polygon"), o = e("../util/shape/Icon"), r = e("../config");
    r.dataZoom = {zlevel: 0,z: 4,show: !1,orient: "horizontal",backgroundColor: "rgba(0,0,0,0)",dataBackgroundColor: "#eee",fillerColor: "rgba(144,197,237,0.2)",handleColor: "rgba(70,130,180,0.8)",handleSize: 8,showDetail: !0,realtime: !0};
    var s = e("../util/date"), l = e("zrender/tool/util");
    return t.prototype = {type: r.COMPONENT_TYPE_DATAZOOM,_buildShape: function() {
            this._buildBackground(), this._buildFiller(), this._buildHandle(), this._buildFrame();
            for (var e = 0, t = this.shapeList.length; t > e; e++)
                this.zr.addShape(this.shapeList[e]);
            this._syncFrameShape()
        },_getLocation: function() {
            var e, t, i, n, a = this.component.grid;
            return "horizontal" == this.zoomOption.orient ? (i = this.zoomOption.width || a.getWidth(), n = this.zoomOption.height || this._fillerSize, e = null != this.zoomOption.x ? this.zoomOption.x : a.getX(), t = null != this.zoomOption.y ? this.zoomOption.y : this.zr.getHeight() - n - 2) : (i = this.zoomOption.width || this._fillerSize, n = this.zoomOption.height || a.getHeight(), e = null != this.zoomOption.x ? this.zoomOption.x : 2, t = null != this.zoomOption.y ? this.zoomOption.y : a.getY()), {x: e,y: t,width: i,height: n}
        },_getZoom: function() {
            var e = this.option.series, t = this.option.xAxis;
            !t || t instanceof Array || (t = [t], this.option.xAxis = t);
            var i = this.option.yAxis;
            !i || i instanceof Array || (i = [i], this.option.yAxis = i);
            var n, a, o = [], s = this.zoomOption.xAxisIndex;
            if (t && null == s) {
                n = [];
                for (var l = 0, h = t.length; h > l; l++)
                    ("category" == t[l].type || null == t[l].type) && n.push(l)
            } else
                n = s instanceof Array ? s : null != s ? [s] : [];
            if (s = this.zoomOption.yAxisIndex, i && null == s) {
                a = [];
                for (var l = 0, h = i.length; h > l; l++)
                    "category" == i[l].type && a.push(l)
            } else
                a = s instanceof Array ? s : null != s ? [s] : [];
            for (var d, l = 0, h = e.length; h > l; l++)
                if (d = e[l], d.type == r.CHART_TYPE_LINE || d.type == r.CHART_TYPE_BAR || d.type == r.CHART_TYPE_SCATTER || d.type == r.CHART_TYPE_K) {
                    for (var c = 0, m = n.length; m > c; c++)
                        if (n[c] == (d.xAxisIndex || 0)) {
                            o.push(l);
                            break
                        }
                    for (var c = 0, m = a.length; m > c; c++)
                        if (a[c] == (d.yAxisIndex || 0)) {
                            o.push(l);
                            break
                        }
                    null == this.zoomOption.xAxisIndex && null == this.zoomOption.yAxisIndex && d.data && this.getDataFromOption(d.data[0]) instanceof Array && (d.type == r.CHART_TYPE_SCATTER || d.type == r.CHART_TYPE_LINE || d.type == r.CHART_TYPE_BAR) && o.push(l)
                }
            var p = null != this._zoom.start ? this._zoom.start : null != this.zoomOption.start ? this.zoomOption.start : 0, u = null != this._zoom.end ? this._zoom.end : null != this.zoomOption.end ? this.zoomOption.end : 100;
            p > u && (p += u, u = p - u, p -= u);
            var V = Math.round((u - p) / 100 * ("horizontal" == this.zoomOption.orient ? this._location.width : this._location.height));
            return {start: p,end: u,start2: 0,end2: 100,size: V,xAxisIndex: n,yAxisIndex: a,seriesIndex: o,scatterMap: this._zoom.scatterMap || {}}
        },_backupData: function() {
            this._originalData = {xAxis: {},yAxis: {},series: {}};
            for (var e = this.option.xAxis, t = this._zoom.xAxisIndex, i = 0, n = t.length; n > i; i++)
                this._originalData.xAxis[t[i]] = e[t[i]].data;
            for (var a = this.option.yAxis, o = this._zoom.yAxisIndex, i = 0, n = o.length; n > i; i++)
                this._originalData.yAxis[o[i]] = a[o[i]].data;
            for (var s, l = this.option.series, h = this._zoom.seriesIndex, i = 0, n = h.length; n > i; i++)
                s = l[h[i]], this._originalData.series[h[i]] = s.data, s.data && this.getDataFromOption(s.data[0]) instanceof Array && (s.type == r.CHART_TYPE_SCATTER || s.type == r.CHART_TYPE_LINE || s.type == r.CHART_TYPE_BAR) && (this._backupScale(), this._calculScatterMap(h[i]))
        },_calculScatterMap: function(t) {
            this._zoom.scatterMap = this._zoom.scatterMap || {}, this._zoom.scatterMap[t] = this._zoom.scatterMap[t] || {};
            var i = e("../component"), n = i.get("axis"), a = l.clone(this.option.xAxis);
            "category" == a[0].type && (a[0].type = "value"), a[1] && "category" == a[1].type && (a[1].type = "value");
            var o = new n(this.ecTheme, null, !1, {xAxis: a,series: this.option.series}, this, "xAxis"), r = this.option.series[t].xAxisIndex || 0;
            this._zoom.scatterMap[t].x = o.getAxis(r).getExtremum(), o.dispose(), a = l.clone(this.option.yAxis), "category" == a[0].type && (a[0].type = "value"), a[1] && "category" == a[1].type && (a[1].type = "value"), o = new n(this.ecTheme, null, !1, {yAxis: a,series: this.option.series}, this, "yAxis"), r = this.option.series[t].yAxisIndex || 0, this._zoom.scatterMap[t].y = o.getAxis(r).getExtremum(), o.dispose()
        },_buildBackground: function() {
            var e = this._location.width, t = this._location.height;
            this.shapeList.push(new n({zlevel: this.getZlevelBase(),z: this.getZBase(),hoverable: !1,style: {x: this._location.x,y: this._location.y,width: e,height: t,color: this.zoomOption.backgroundColor}}));
            for (var i = 0, o = this._originalData.xAxis, s = this._zoom.xAxisIndex, l = 0, h = s.length; h > l; l++)
                i = Math.max(i, o[s[l]].length);
            for (var d = this._originalData.yAxis, c = this._zoom.yAxisIndex, l = 0, h = c.length; h > l; l++)
                i = Math.max(i, d[c[l]].length);
            for (var m, p = this._zoom.seriesIndex[0], u = this._originalData.series[p], V = Number.MIN_VALUE, U = Number.MAX_VALUE, l = 0, h = u.length; h > l; l++)
                m = this.getDataFromOption(u[l], 0), this.option.series[p].type == r.CHART_TYPE_K && (m = m[1]), isNaN(m) && (m = 0), V = Math.max(V, m), U = Math.min(U, m);
            var g = V - U, f = [], y = e / (i - (i > 1 ? 1 : 0)), b = t / (i - (i > 1 ? 1 : 0)), _ = 1;
            "horizontal" == this.zoomOption.orient && 1 > y ? _ = Math.floor(3 * i / e) : "vertical" == this.zoomOption.orient && 1 > b && (_ = Math.floor(3 * i / t));
            for (var l = 0, h = i; h > l; l += _)
                m = this.getDataFromOption(u[l], 0), this.option.series[p].type == r.CHART_TYPE_K && (m = m[1]), isNaN(m) && (m = 0), f.push("horizontal" == this.zoomOption.orient ? [this._location.x + y * l, this._location.y + t - 1 - Math.round((m - U) / g * (t - 10))] : [this._location.x + 1 + Math.round((m - U) / g * (e - 10)), this._location.y + b * (h - l - 1)]);
            
            "horizontal" == this.zoomOption.orient ? (f.push([this._location.x + e, this._location.y + t]), f.push([this._location.x, this._location.y + t])) : (f.push([this._location.x, this._location.y]), f.push([this._location.x, this._location.y + t])), this.shapeList.push(new a({zlevel: this.getZlevelBase(),z: this.getZBase(),style: {pointList: f,color: this.zoomOption.dataBackgroundColor},hoverable: !1}))
        },_buildFiller: function() {
            this._fillerShae = {zlevel: this.getZlevelBase(),z: this.getZBase(),draggable: !0,ondrift: this._ondrift,ondragend: this._ondragend,_type: "filler"}, this._fillerShae.style = "horizontal" == this.zoomOption.orient ? {x: this._location.x + Math.round(this._zoom.start / 100 * this._location.width) + this._handleSize,y: this._location.y,width: this._zoom.size - 2 * this._handleSize,height: this._location.height,color: this.zoomOption.fillerColor,text: ":::",textPosition: "inside"} : {x: this._location.x,y: this._location.y + Math.round(this._zoom.start / 100 * this._location.height) + this._handleSize,width: this._location.width,height: this._zoom.size - 2 * this._handleSize,color: this.zoomOption.fillerColor,text: "::",textPosition: "inside"}, this._fillerShae.highlightStyle = {brushType: "fill",color: "rgba(0,0,0,0)"}, this._fillerShae = new n(this._fillerShae), this.shapeList.push(this._fillerShae)
        },_buildHandle: function() {
            var e = this.zoomOption.showDetail ? this._getDetail() : {start: "",end: ""};
            this._startShape = {zlevel: this.getZlevelBase(),z: this.getZBase(),draggable: !0,style: {iconType: "rectangle",x: this._location.x,y: this._location.y,width: this._handleSize,height: this._handleSize,color: this.zoomOption.handleColor,text: "=",textPosition: "inside"},highlightStyle: {text: e.start,brushType: "fill",textPosition: "left"},ondrift: this._ondrift,ondragend: this._ondragend}, "horizontal" == this.zoomOption.orient ? (this._startShape.style.height = this._location.height, this._endShape = l.clone(this._startShape), this._startShape.style.x = this._fillerShae.style.x - this._handleSize, this._endShape.style.x = this._fillerShae.style.x + this._fillerShae.style.width, this._endShape.highlightStyle.text = e.end, this._endShape.highlightStyle.textPosition = "right") : (this._startShape.style.width = this._location.width, this._endShape = l.clone(this._startShape), this._startShape.style.y = this._fillerShae.style.y + this._fillerShae.style.height, this._startShape.highlightStyle.textPosition = "bottom", this._endShape.style.y = this._fillerShae.style.y - this._handleSize, this._endShape.highlightStyle.text = e.end, this._endShape.highlightStyle.textPosition = "top"), this._startShape = new o(this._startShape), this._endShape = new o(this._endShape), this.shapeList.push(this._startShape), this.shapeList.push(this._endShape)
        },_buildFrame: function() {
            var e = this.subPixelOptimize(this._location.x, 1), t = this.subPixelOptimize(this._location.y, 1);
            this._startFrameShape = {zlevel: this.getZlevelBase(),z: this.getZBase(),hoverable: !1,style: {x: e,y: t,width: this._location.width - (e > this._location.x ? 1 : 0),height: this._location.height - (t > this._location.y ? 1 : 0),lineWidth: 1,brushType: "stroke",strokeColor: this.zoomOption.handleColor}}, this._endFrameShape = l.clone(this._startFrameShape), this._startFrameShape = new n(this._startFrameShape), this._endFrameShape = new n(this._endFrameShape), this.shapeList.push(this._startFrameShape), this.shapeList.push(this._endFrameShape)
        },_syncHandleShape: function() {
            "horizontal" == this.zoomOption.orient ? (this._startShape.style.x = this._fillerShae.style.x - this._handleSize, this._endShape.style.x = this._fillerShae.style.x + this._fillerShae.style.width, this._zoom.start = (this._startShape.style.x - this._location.x) / this._location.width * 100, this._zoom.end = (this._endShape.style.x + this._handleSize - this._location.x) / this._location.width * 100) : (this._startShape.style.y = this._fillerShae.style.y + this._fillerShae.style.height, this._endShape.style.y = this._fillerShae.style.y - this._handleSize, this._zoom.start = (this._location.y + this._location.height - this._startShape.style.y) / this._location.height * 100, this._zoom.end = (this._location.y + this._location.height - this._endShape.style.y - this._handleSize) / this._location.height * 100), this.zr.modShape(this._startShape.id), this.zr.modShape(this._endShape.id), this._syncFrameShape(), this.zr.refreshNextFrame()
        },_syncFillerShape: function() {
            var e, t;
            "horizontal" == this.zoomOption.orient ? (e = this._startShape.style.x, t = this._endShape.style.x, this._fillerShae.style.x = Math.min(e, t) + this._handleSize, this._fillerShae.style.width = Math.abs(e - t) - this._handleSize, this._zoom.start = (Math.min(e, t) - this._location.x) / this._location.width * 100, this._zoom.end = (Math.max(e, t) + this._handleSize - this._location.x) / this._location.width * 100) : (e = this._startShape.style.y, t = this._endShape.style.y, this._fillerShae.style.y = Math.min(e, t) + this._handleSize, this._fillerShae.style.height = Math.abs(e - t) - this._handleSize, this._zoom.start = (this._location.y + this._location.height - Math.max(e, t)) / this._location.height * 100, this._zoom.end = (this._location.y + this._location.height - Math.min(e, t) - this._handleSize) / this._location.height * 100), this.zr.modShape(this._fillerShae.id), this._syncFrameShape(), this.zr.refreshNextFrame()
        },_syncFrameShape: function() {
            "horizontal" == this.zoomOption.orient ? (this._startFrameShape.style.width = this._fillerShae.style.x - this._location.x, this._endFrameShape.style.x = this._fillerShae.style.x + this._fillerShae.style.width, this._endFrameShape.style.width = this._location.x + this._location.width - this._endFrameShape.style.x) : (this._startFrameShape.style.y = this._fillerShae.style.y + this._fillerShae.style.height, this._startFrameShape.style.height = this._location.y + this._location.height - this._startFrameShape.style.y, this._endFrameShape.style.height = this._fillerShae.style.y - this._location.y), this.zr.modShape(this._startFrameShape.id), this.zr.modShape(this._endFrameShape.id)
        },_syncShape: function() {
            this.zoomOption.show && ("horizontal" == this.zoomOption.orient ? (this._startShape.style.x = this._location.x + this._zoom.start / 100 * this._location.width, this._endShape.style.x = this._location.x + this._zoom.end / 100 * this._location.width - this._handleSize, this._fillerShae.style.x = this._startShape.style.x + this._handleSize, this._fillerShae.style.width = this._endShape.style.x - this._startShape.style.x - this._handleSize) : (this._startShape.style.y = this._location.y + this._location.height - this._zoom.start / 100 * this._location.height, this._endShape.style.y = this._location.y + this._location.height - this._zoom.end / 100 * this._location.height - this._handleSize, this._fillerShae.style.y = this._endShape.style.y + this._handleSize, this._fillerShae.style.height = this._startShape.style.y - this._endShape.style.y - this._handleSize), this.zr.modShape(this._startShape.id), this.zr.modShape(this._endShape.id), this.zr.modShape(this._fillerShae.id), this._syncFrameShape(), this.zr.refresh())
        },_syncData: function(e) {
            var t, i, n, a, o;
            for (var s in this._originalData) {
                t = this._originalData[s];
                for (var l in t)
                    o = t[l], null != o && (a = o.length, i = Math.floor(this._zoom.start / 100 * a), n = Math.ceil(this._zoom.end / 100 * a), this.getDataFromOption(o[0]) instanceof Array && this.option[s][l].type != r.CHART_TYPE_K ? (this._setScale(), this.option[s][l].data = this._synScatterData(l, o)) : this.option[s][l].data = o.slice(i, n))
            }
            this._isSilence || !this.zoomOption.realtime && !e || this.messageCenter.dispatch(r.EVENT.DATA_ZOOM, null, {zoom: this._zoom}, this.myChart)
        },_synScatterData: function(e, t) {
            if (0 === this._zoom.start && 100 == this._zoom.end && 0 === this._zoom.start2 && 100 == this._zoom.end2)
                return t;
            var i, n, a, o, r, s = [], l = this._zoom.scatterMap[e];
            "horizontal" == this.zoomOption.orient ? (i = l.x.max - l.x.min, n = this._zoom.start / 100 * i + l.x.min, a = this._zoom.end / 100 * i + l.x.min, i = l.y.max - l.y.min, o = this._zoom.start2 / 100 * i + l.y.min, r = this._zoom.end2 / 100 * i + l.y.min) : (i = l.x.max - l.x.min, n = this._zoom.start2 / 100 * i + l.x.min, a = this._zoom.end2 / 100 * i + l.x.min, i = l.y.max - l.y.min, o = this._zoom.start / 100 * i + l.y.min, r = this._zoom.end / 100 * i + l.y.min);
            var h;
            (h = l.x.dataMappingMethods) && (n = h.coord2Value(n), a = h.coord2Value(a)), (h = l.y.dataMappingMethods) && (o = h.coord2Value(o), r = h.coord2Value(r));
            for (var d, c = 0, m = t.length; m > c; c++)
                d = t[c].value || t[c], d[0] >= n && d[0] <= a && d[1] >= o && d[1] <= r && s.push(t[c]);
            return s
        },_setScale: function() {
            var e = 0 !== this._zoom.start || 100 !== this._zoom.end || 0 !== this._zoom.start2 || 100 !== this._zoom.end2, t = {xAxis: this.option.xAxis,yAxis: this.option.yAxis};
            for (var i in t)
                for (var n = 0, a = t[i].length; a > n; n++)
                    t[i][n].scale = e || t[i][n]._scale
        },_backupScale: function() {
            var e = {xAxis: this.option.xAxis,yAxis: this.option.yAxis};
            for (var t in e)
                for (var i = 0, n = e[t].length; n > i; i++)
                    e[t][i]._scale = e[t][i].scale
        },_getDetail: function() {
            for (var e = ["xAxis", "yAxis"], t = 0, i = e.length; i > t; t++) {
                var n = this._originalData[e[t]];
                for (var a in n) {
                    var o = n[a];
                    if (null != o) {
                        var r = o.length, l = Math.floor(this._zoom.start / 100 * r), h = Math.ceil(this._zoom.end / 100 * r);
                        return h -= h > 0 ? 1 : 0, {start: this.getDataFromOption(o[l]),end: this.getDataFromOption(o[h])}
                    }
                }
            }
            e = "horizontal" == this.zoomOption.orient ? "xAxis" : "yAxis";
            var d = this._zoom.seriesIndex[0], c = this.option.series[d][e + "Index"] || 0, m = this.option[e][c].type, p = this._zoom.scatterMap[d][e.charAt(0)].min, u = this._zoom.scatterMap[d][e.charAt(0)].max, V = u - p;
            if ("value" == m)
                return {start: p + V * this._zoom.start / 100,end: p + V * this._zoom.end / 100};
            if ("time" == m) {
                u = p + V * this._zoom.end / 100, p += V * this._zoom.start / 100;
                var U = s.getAutoFormatter(p, u).formatter;
                return {start: s.format(U, p),end: s.format(U, u)}
            }
            return {start: "",end: ""}
        },__ondrift: function(e, t, i) {
            this.zoomOption.zoomLock && (e = this._fillerShae);
            var n = "filler" == e._type ? this._handleSize : 0;
            if ("horizontal" == this.zoomOption.orient ? e.style.x + t - n <= this._location.x ? e.style.x = this._location.x + n : e.style.x + t + e.style.width + n >= this._location.x + this._location.width ? e.style.x = this._location.x + this._location.width - e.style.width - n : e.style.x += t : e.style.y + i - n <= this._location.y ? e.style.y = this._location.y + n : e.style.y + i + e.style.height + n >= this._location.y + this._location.height ? e.style.y = this._location.y + this._location.height - e.style.height - n : e.style.y += i, "filler" == e._type ? this._syncHandleShape() : this._syncFillerShape(), this.zoomOption.realtime && this._syncData(), this.zoomOption.showDetail) {
                var a = this._getDetail();
                this._startShape.style.text = this._startShape.highlightStyle.text = a.start, this._endShape.style.text = this._endShape.highlightStyle.text = a.end, this._startShape.style.textPosition = this._startShape.highlightStyle.textPosition, this._endShape.style.textPosition = this._endShape.highlightStyle.textPosition
            }
            return !0
        },__ondragend: function() {
            this.zoomOption.showDetail && (this._startShape.style.text = this._endShape.style.text = "=", this._startShape.style.textPosition = this._endShape.style.textPosition = "inside", this.zr.modShape(this._startShape.id), this.zr.modShape(this._endShape.id), this.zr.refreshNextFrame()), this.isDragend = !0
        },ondragend: function(e, t) {
            this.isDragend && e.target && (!this.zoomOption.realtime && this._syncData(), t.dragOut = !0, t.dragIn = !0, this._isSilence || this.zoomOption.realtime || this.messageCenter.dispatch(r.EVENT.DATA_ZOOM, null, {zoom: this._zoom}, this.myChart), t.needRefresh = !1, this.isDragend = !1)
        },ondataZoom: function(e, t) {
            t.needRefresh = !0
        },absoluteZoom: function(e) {
            this._zoom.start = e.start, this._zoom.end = e.end, this._zoom.start2 = e.start2, this._zoom.end2 = e.end2, this._syncShape(), this._syncData(!0)
        },rectZoom: function(e) {
            if (!e)
                return this._zoom.start = this._zoom.start2 = 0, this._zoom.end = this._zoom.end2 = 100, this._syncShape(), this._syncData(!0), this._zoom;
            var t = this.component.grid.getArea(), i = {x: e.x,y: e.y,width: e.width,height: e.height};
            if (i.width < 0 && (i.x += i.width, i.width = -i.width), i.height < 0 && (i.y += i.height, i.height = -i.height), i.x > t.x + t.width || i.y > t.y + t.height)
                return !1;
            i.x < t.x && (i.x = t.x), i.x + i.width > t.x + t.width && (i.width = t.x + t.width - i.x), i.y + i.height > t.y + t.height && (i.height = t.y + t.height - i.y);
            var n, a = (i.x - t.x) / t.width, o = 1 - (i.x + i.width - t.x) / t.width, r = 1 - (i.y + i.height - t.y) / t.height, s = (i.y - t.y) / t.height;
            return "horizontal" == this.zoomOption.orient ? (n = this._zoom.end - this._zoom.start, this._zoom.start += n * a, this._zoom.end -= n * o, n = this._zoom.end2 - this._zoom.start2, this._zoom.start2 += n * r, this._zoom.end2 -= n * s) : (n = this._zoom.end - this._zoom.start, this._zoom.start += n * r, this._zoom.end -= n * s, n = this._zoom.end2 - this._zoom.start2, this._zoom.start2 += n * a, this._zoom.end2 -= n * o), this._syncShape(), this._syncData(!0), this._zoom
        },syncBackupData: function(e) {
            for (var t, i, n = this._originalData.series, a = e.series, o = 0, r = a.length; r > o; o++) {
                i = a[o].data || a[o].eventList, t = n[o] ? Math.floor(this._zoom.start / 100 * n[o].length) : 0;
                for (var s = 0, l = i.length; l > s; s++)
                    n[o] && (n[o][s + t] = i[s])
            }
        },syncOption: function(e) {
            this.silence(!0), this.option = e, this.option.dataZoom = this.reformOption(this.option.dataZoom), this.zoomOption = this.option.dataZoom, this.myChart.canvasSupported || (this.zoomOption.realtime = !1), this.clear(), this._location = this._getLocation(), this._zoom = this._getZoom(), this._backupData(), this.option.dataZoom && this.option.dataZoom.show && this._buildShape(), this._syncData(), this.silence(!1)
        },silence: function(e) {
            this._isSilence = e
        },getRealDataIndex: function(e, t) {
            if (!this._originalData || 0 === this._zoom.start && 100 == this._zoom.end)
                return t;
            var i = this._originalData.series;
            return i[e] ? Math.floor(this._zoom.start / 100 * i[e].length) + t : -1
        },resize: function() {
            this.clear(), this._location = this._getLocation(), this._zoom = this._getZoom(), this.option.dataZoom.show && this._buildShape()
        }}, l.inherits(t, i), e("../component").define("dataZoom", t), t
}), define("echarts/component/categoryAxis", ["require", "./base", "zrender/shape/Text", "zrender/shape/Line", "zrender/shape/Rectangle", "../config", "zrender/tool/util", "zrender/tool/area", "../component"], function(e) {
    function t(e, t, n, a, o, r) {
        if (a.data.length < 1)
            return void console.error("option.data.length < 1.");
        i.call(this, e, t, n, a, o), this.grid = this.component.grid;
        for (var s in r)
            this[s] = r[s];
        this.refresh(a)
    }
    var i = e("./base"), n = e("zrender/shape/Text"), a = e("zrender/shape/Line"), o = e("zrender/shape/Rectangle"), r = e("../config");
    r.categoryAxis = {zlevel: 0,z: 0,show: !0,position: "bottom",name: "",nameLocation: "end",nameTextStyle: {},boundaryGap: !0,axisLine: {show: !0,onZero: !0,lineStyle: {color: "#48b",width: 2,type: "solid"}},axisTick: {show: !0,interval: "auto",inside: !1,length: 5,lineStyle: {color: "#333",width: 1}},axisLabel: {show: !0,interval: "auto",rotate: 0,margin: 8,textStyle: {color: "#333"}},splitLine: {show: !0,lineStyle: {color: ["#ccc"],width: 1,type: "solid"}},splitArea: {show: !1,areaStyle: {color: ["rgba(250,250,250,0.3)", "rgba(200,200,200,0.3)"]}}};
    var s = e("zrender/tool/util"), l = e("zrender/tool/area");
    return t.prototype = {type: r.COMPONENT_TYPE_AXIS_CATEGORY,_getReformedLabel: function(e) {
            var t = this.getDataFromOption(this.option.data[e]), i = this.option.data[e].formatter || this.option.axisLabel.formatter;
            return i && ("function" == typeof i ? t = i.call(this.myChart, t) : "string" == typeof i && (t = i.replace("{value}", t))), t
        },_getInterval: function() {
            var e = this.option.axisLabel.interval;
            if ("auto" == e) {
                var t = this.option.axisLabel.textStyle.fontSize, i = this.option.data, n = this.option.data.length;
                if (this.isHorizontal())
                    if (n > 3) {
                        var a, o, r = this.getGap(), h = !1, d = Math.floor(.5 / r);
                        for (d = 1 > d ? 1 : d, e = Math.floor(15 / r); !h && n > e; ) {
                            e += d, h = !0, a = Math.floor(r * e);
                            for (var c = Math.floor((n - 1) / e) * e; c >= 0; c -= e) {
                                if (0 !== this.option.axisLabel.rotate)
                                    o = t;
                                else if (i[c].textStyle)
                                    o = l.getTextWidth(this._getReformedLabel(c), this.getFont(s.merge(i[c].textStyle, this.option.axisLabel.textStyle)));
                                else {
                                    var m = this._getReformedLabel(c) + "", p = (m.match(/\w/g) || "").length, u = m.length - p;
                                    o = p * t * 2 / 3 + u * t
                                }
                                if (o > a) {
                                    h = !1;
                                    break
                                }
                            }
                        }
                    } else
                        e = 1;
                else if (n > 3) {
                    var r = this.getGap();
                    for (e = Math.floor(11 / r); t > r * e - 6 && n > e; )
                        e++
                } else
                    e = 1
            } else
                e = "function" == typeof e ? 1 : e - 0 + 1;
            return e
        },_buildShape: function() {
            if (this._interval = this._getInterval(), this.option.show) {
                this.option.splitArea.show && this._buildSplitArea(), this.option.splitLine.show && this._buildSplitLine(), this.option.axisLine.show && this._buildAxisLine(), this.option.axisTick.show && this._buildAxisTick(), this.option.axisLabel.show && this._buildAxisLabel();
                for (var e = 0, t = this.shapeList.length; t > e; e++)
                    this.zr.addShape(this.shapeList[e])
            }
        },_buildAxisTick: function() {
            var e, t = this.option.data, i = this.option.data.length, n = this.option.axisTick, o = n.length, r = n.lineStyle.color, s = n.lineStyle.width, l = "function" == typeof n.interval ? n.interval : "auto" == n.interval && "function" == typeof this.option.axisLabel.interval ? this.option.axisLabel.interval : !1, h = l ? 1 : "auto" == n.interval ? this._interval : n.interval - 0 + 1, d = n.onGap, c = d ? this.getGap() / 2 : "undefined" == typeof d && this.option.boundaryGap ? this.getGap() / 2 : 0, m = c > 0 ? -h : 0;
            if (this.isHorizontal())
                for (var p, u = "bottom" == this.option.position ? n.inside ? this.grid.getYend() - o - 1 : this.grid.getYend() + 1 : n.inside ? this.grid.getY() + 1 : this.grid.getY() - o - 1, V = m; i > V; V += h)
                    (!l || l(V, t[V])) && (p = this.subPixelOptimize(this.getCoordByIndex(V) + (V >= 0 ? c : 0), s), e = {_axisShape: "axisTick",zlevel: this.getZlevelBase(),z: this.getZBase(),hoverable: !1,style: {xStart: p,yStart: u,xEnd: p,yEnd: u + o,strokeColor: r,lineWidth: s}}, this.shapeList.push(new a(e)));
            else
                for (var U, g = "left" == this.option.position ? n.inside ? this.grid.getX() + 1 : this.grid.getX() - o - 1 : n.inside ? this.grid.getXend() - o - 1 : this.grid.getXend() + 1, V = m; i > V; V += h)
                    (!l || l(V, t[V])) && (U = this.subPixelOptimize(this.getCoordByIndex(V) - (V >= 0 ? c : 0), s), e = {_axisShape: "axisTick",zlevel: this.getZlevelBase(),z: this.getZBase(),hoverable: !1,style: {xStart: g,yStart: U,xEnd: g + o,yEnd: U,strokeColor: r,lineWidth: s}}, this.shapeList.push(new a(e)))
        },_buildAxisLabel: function() {
            var e, t, i = this.option.data, a = this.option.data.length, o = this.option.axisLabel, r = o.rotate, l = o.margin, h = o.clickable, d = o.textStyle, c = "function" == typeof o.interval ? o.interval : !1;
            if (this.isHorizontal()) {
                var m, p;
                "bottom" == this.option.position ? (m = this.grid.getYend() + l, p = "top") : (m = this.grid.getY() - l, p = "bottom");
                for (var u = 0; a > u; u += this._interval)
                    c && !c(u, i[u]) || "" === this._getReformedLabel(u) || (t = s.merge(i[u].textStyle || {}, d), e = {zlevel: this.getZlevelBase(),z: this.getZBase() + 3,hoverable: !1,style: {x: this.getCoordByIndex(u),y: m,color: t.color,text: this._getReformedLabel(u),textFont: this.getFont(t),textAlign: t.align || "center",textBaseline: t.baseline || p}}, r && (e.style.textAlign = r > 0 ? "bottom" == this.option.position ? "right" : "left" : "bottom" == this.option.position ? "left" : "right", e.rotation = [r * Math.PI / 180, e.style.x, e.style.y]), this.shapeList.push(new n(this._axisLabelClickable(h, e))))
            } else {
                var V, U;
                "left" == this.option.position ? (V = this.grid.getX() - l, U = "right") : (V = this.grid.getXend() + l, U = "left");
                for (var u = 0; a > u; u += this._interval)
                    c && !c(u, i[u]) || "" === this._getReformedLabel(u) || (t = s.merge(i[u].textStyle || {}, d), e = {zlevel: this.getZlevelBase(),z: this.getZBase() + 3,hoverable: !1,style: {x: V,y: this.getCoordByIndex(u),color: t.color,text: this._getReformedLabel(u),textFont: this.getFont(t),textAlign: t.align || U,textBaseline: t.baseline || 0 === u && "" !== this.option.name ? "bottom" : u == a - 1 && "" !== this.option.name ? "top" : "middle"}}, r && (e.rotation = [r * Math.PI / 180, e.style.x, e.style.y]), this.shapeList.push(new n(this._axisLabelClickable(h, e))))
            }
        },_buildSplitLine: function() {
            var e, t = this.option.data, i = this.option.data.length, n = this.option.splitLine, o = n.lineStyle.type, r = n.lineStyle.width, s = n.lineStyle.color;
            s = s instanceof Array ? s : [s];
            var l = s.length, h = "function" == typeof this.option.axisLabel.interval ? this.option.axisLabel.interval : !1, d = n.onGap, c = d ? this.getGap() / 2 : "undefined" == typeof d && this.option.boundaryGap ? this.getGap() / 2 : 0;
            if (i -= d || "undefined" == typeof d && this.option.boundaryGap ? 1 : 0, this.isHorizontal())
                for (var m, p = this.grid.getY(), u = this.grid.getYend(), V = 0; i > V; V += this._interval)
                    (!h || h(V, t[V])) && (m = this.subPixelOptimize(this.getCoordByIndex(V) + c, r), e = {zlevel: this.getZlevelBase(),z: this.getZBase(),hoverable: !1,style: {xStart: m,yStart: p,xEnd: m,yEnd: u,strokeColor: s[V / this._interval % l],lineType: o,lineWidth: r}}, this.shapeList.push(new a(e)));
            else
                for (var U, g = this.grid.getX(), f = this.grid.getXend(), V = 0; i > V; V += this._interval)
                    (!h || h(V, t[V])) && (U = this.subPixelOptimize(this.getCoordByIndex(V) - c, r), e = {zlevel: this.getZlevelBase(),z: this.getZBase(),hoverable: !1,style: {xStart: g,yStart: U,xEnd: f,yEnd: U,strokeColor: s[V / this._interval % l],lineType: o,lineWidth: r}}, this.shapeList.push(new a(e)))
        },_buildSplitArea: function() {
            var e, t = this.option.data, i = this.option.splitArea, n = i.areaStyle.color;
            if (n instanceof Array) {
                var a = n.length, r = this.option.data.length, s = "function" == typeof this.option.axisLabel.interval ? this.option.axisLabel.interval : !1, l = i.onGap, h = l ? this.getGap() / 2 : "undefined" == typeof l && this.option.boundaryGap ? this.getGap() / 2 : 0;
                if (this.isHorizontal())
                    for (var d, c = this.grid.getY(), m = this.grid.getHeight(), p = this.grid.getX(), u = 0; r >= u; u += this._interval)
                        s && !s(u, t[u]) && r > u || (d = r > u ? this.getCoordByIndex(u) + h : this.grid.getXend(), e = {zlevel: this.getZlevelBase(),z: this.getZBase(),hoverable: !1,style: {x: p,y: c,width: d - p,height: m,color: n[u / this._interval % a]}}, this.shapeList.push(new o(e)), p = d);
                else
                    for (var V, U = this.grid.getX(), g = this.grid.getWidth(), f = this.grid.getYend(), u = 0; r >= u; u += this._interval)
                        s && !s(u, t[u]) && r > u || (V = r > u ? this.getCoordByIndex(u) - h : this.grid.getY(), e = {zlevel: this.getZlevelBase(),z: this.getZBase(),hoverable: !1,style: {x: U,y: V,width: g,height: f - V,color: n[u / this._interval % a]}}, this.shapeList.push(new o(e)), f = V)
            } else
                e = {zlevel: this.getZlevelBase(),z: this.getZBase(),hoverable: !1,style: {x: this.grid.getX(),y: this.grid.getY(),width: this.grid.getWidth(),height: this.grid.getHeight(),color: n}}, this.shapeList.push(new o(e))
        },refresh: function(e) {
            e && (this.option = this.reformOption(e), this.option.axisLabel.textStyle = this.getTextStyle(this.option.axisLabel.textStyle)), this.clear(), this._buildShape()
        },getGap: function() {
            var e = this.option.data.length, t = this.isHorizontal() ? this.grid.getWidth() : this.grid.getHeight();
            return this.option.boundaryGap ? t / e : t / (e > 1 ? e - 1 : 1)
        },getCoord: function(e) {
            for (var t = this.option.data, i = t.length, n = this.getGap(), a = this.option.boundaryGap ? n / 2 : 0, o = 0; i > o; o++) {
                if (this.getDataFromOption(t[o]) == e)
                    return a = this.isHorizontal() ? this.grid.getX() + a : this.grid.getYend() - a;
                a += n
            }
        },getCoordByIndex: function(e) {
            if (0 > e)
                return this.isHorizontal() ? this.grid.getX() : this.grid.getYend();
            if (e > this.option.data.length - 1)
                return this.isHorizontal() ? this.grid.getXend() : this.grid.getY();
            var t = this.getGap(), i = this.option.boundaryGap ? t / 2 : 0;
            return i += e * t, i = this.isHorizontal() ? this.grid.getX() + i : this.grid.getYend() - i
        },getNameByIndex: function(e) {
            return this.getDataFromOption(this.option.data[e])
        },getIndexByName: function(e) {
            for (var t = this.option.data, i = t.length, n = 0; i > n; n++)
                if (this.getDataFromOption(t[n]) == e)
                    return n;
            return -1
        },getValueFromCoord: function() {
            return ""
        },isMainAxis: function(e) {
            return e % this._interval === 0
        }}, s.inherits(t, i), e("../component").define("categoryAxis", t), t
}), define("echarts/component/valueAxis", ["require", "./base", "zrender/shape/Text", "zrender/shape/Line", "zrender/shape/Rectangle", "../config", "../util/date", "zrender/tool/util", "../util/smartSteps", "../util/accMath", "../util/smartLogSteps", "../component"], function(e) {
    function t(e, t, n, a, o, r, s) {
        if (!s || 0 === s.length)
            return void console.err("option.series.length == 0.");
        i.call(this, e, t, n, a, o), this.series = s, this.grid = this.component.grid;
        for (var l in r)
            this[l] = r[l];
        this.refresh(a, s)
    }
    var i = e("./base"), n = e("zrender/shape/Text"), a = e("zrender/shape/Line"), o = e("zrender/shape/Rectangle"), r = e("../config");
    r.valueAxis = {zlevel: 0,z: 0,show: !0,position: "left",name: "",nameLocation: "end",nameTextStyle: {},boundaryGap: [0, 0],axisLine: {show: !0,onZero: !0,lineStyle: {color: "#48b",width: 2,type: "solid"}},axisTick: {show: !1,inside: !1,length: 5,lineStyle: {color: "#333",width: 1}},axisLabel: {show: !0,rotate: 0,margin: 8,textStyle: {color: "#333"}},splitLine: {show: !0,lineStyle: {color: ["#ccc"],width: 1,type: "solid"}},splitArea: {show: !1,areaStyle: {color: ["rgba(250,250,250,0.3)", "rgba(200,200,200,0.3)"]}}};
    var s = e("../util/date"), l = e("zrender/tool/util");
    return t.prototype = {type: r.COMPONENT_TYPE_AXIS_VALUE,_buildShape: function() {
            if (this._hasData = !1, this._calculateValue(), this._hasData && this.option.show) {
                this.option.splitArea.show && this._buildSplitArea(), this.option.splitLine.show && this._buildSplitLine(), this.option.axisLine.show && this._buildAxisLine(), this.option.axisTick.show && this._buildAxisTick(), this.option.axisLabel.show && this._buildAxisLabel();
                for (var e = 0, t = this.shapeList.length; t > e; e++)
                    this.zr.addShape(this.shapeList[e])
            }
        },_buildAxisTick: function() {
            var e, t = this._valueList, i = this._valueList.length, n = this.option.axisTick, o = n.length, r = n.lineStyle.color, s = n.lineStyle.width;
            if (this.isHorizontal())
                for (var l, h = "bottom" === this.option.position ? n.inside ? this.grid.getYend() - o - 1 : this.grid.getYend() + 1 : n.inside ? this.grid.getY() + 1 : this.grid.getY() - o - 1, d = 0; i > d; d++)
                    l = this.subPixelOptimize(this.getCoord(t[d]), s), e = {_axisShape: "axisTick",zlevel: this.getZlevelBase(),z: this.getZBase(),hoverable: !1,style: {xStart: l,yStart: h,xEnd: l,yEnd: h + o,strokeColor: r,lineWidth: s}}, this.shapeList.push(new a(e));
            else
                for (var c, m = "left" === this.option.position ? n.inside ? this.grid.getX() + 1 : this.grid.getX() - o - 1 : n.inside ? this.grid.getXend() - o - 1 : this.grid.getXend() + 1, d = 0; i > d; d++)
                    c = this.subPixelOptimize(this.getCoord(t[d]), s), e = {_axisShape: "axisTick",zlevel: this.getZlevelBase(),z: this.getZBase(),hoverable: !1,style: {xStart: m,yStart: c,xEnd: m + o,yEnd: c,strokeColor: r,lineWidth: s}}, this.shapeList.push(new a(e))
        },_buildAxisLabel: function() {
            var e, t = this._valueList, i = this._valueList.length, a = this.option.axisLabel.rotate, o = this.option.axisLabel.margin, r = this.option.axisLabel.clickable, s = this.option.axisLabel.textStyle;
            if (this.isHorizontal()) {
                var l, h;
                "bottom" === this.option.position ? (l = this.grid.getYend() + o, h = "top") : (l = this.grid.getY() - o, h = "bottom");
                for (var d = 0; i > d; d++)
                    e = {zlevel: this.getZlevelBase(),z: this.getZBase() + 3,hoverable: !1,style: {x: this.getCoord(t[d]),y: l,color: "function" == typeof s.color ? s.color(t[d]) : s.color,text: this._valueLabel[d],textFont: this.getFont(s),textAlign: s.align || "center",textBaseline: s.baseline || h}}, a && (e.style.textAlign = a > 0 ? "bottom" === this.option.position ? "right" : "left" : "bottom" === this.option.position ? "left" : "right", e.rotation = [a * Math.PI / 180, e.style.x, e.style.y]), this.shapeList.push(new n(this._axisLabelClickable(r, e)))
            } else {
                var c, m;
                "left" === this.option.position ? (c = this.grid.getX() - o, m = "right") : (c = this.grid.getXend() + o, m = "left");
                for (var d = 0; i > d; d++)
                    e = {zlevel: this.getZlevelBase(),z: this.getZBase() + 3,hoverable: !1,style: {x: c,y: this.getCoord(t[d]),color: "function" == typeof s.color ? s.color(t[d]) : s.color,text: this._valueLabel[d],textFont: this.getFont(s),textAlign: s.align || m,textBaseline: s.baseline || (0 === d && "" !== this.option.name ? "bottom" : d === i - 1 && "" !== this.option.name ? "top" : "middle")}}, a && (e.rotation = [a * Math.PI / 180, e.style.x, e.style.y]), this.shapeList.push(new n(this._axisLabelClickable(r, e)))
            }
        },_buildSplitLine: function() {
            var e, t = this._valueList, i = this._valueList.length, n = this.option.splitLine, o = n.lineStyle.type, r = n.lineStyle.width, s = n.lineStyle.color;
            s = s instanceof Array ? s : [s];
            var l = s.length;
            if (this.isHorizontal())
                for (var h, d = this.grid.getY(), c = this.grid.getYend(), m = 0; i > m; m++)
                    h = this.subPixelOptimize(this.getCoord(t[m]), r), e = {zlevel: this.getZlevelBase(),z: this.getZBase(),hoverable: !1,style: {xStart: h,yStart: d,xEnd: h,yEnd: c,strokeColor: s[m % l],lineType: o,lineWidth: r}}, this.shapeList.push(new a(e));
            else
                for (var p, u = this.grid.getX(), V = this.grid.getXend(), m = 0; i > m; m++)
                    p = this.subPixelOptimize(this.getCoord(t[m]), r), e = {zlevel: this.getZlevelBase(),z: this.getZBase(),hoverable: !1,style: {xStart: u,yStart: p,xEnd: V,yEnd: p,strokeColor: s[m % l],lineType: o,lineWidth: r}}, this.shapeList.push(new a(e))
        },_buildSplitArea: function() {
            var e, t = this.option.splitArea.areaStyle.color;
            if (t instanceof Array) {
                var i = t.length, n = this._valueList, a = this._valueList.length;
                if (this.isHorizontal())
                    for (var r, s = this.grid.getY(), l = this.grid.getHeight(), h = this.grid.getX(), d = 0; a >= d; d++)
                        r = a > d ? this.getCoord(n[d]) : this.grid.getXend(), e = {zlevel: this.getZlevelBase(),z: this.getZBase(),hoverable: !1,style: {x: h,y: s,width: r - h,height: l,color: t[d % i]}}, this.shapeList.push(new o(e)), h = r;
                else
                    for (var c, m = this.grid.getX(), p = this.grid.getWidth(), u = this.grid.getYend(), d = 0; a >= d; d++)
                        c = a > d ? this.getCoord(n[d]) : this.grid.getY(), e = {zlevel: this.getZlevelBase(),z: this.getZBase(),hoverable: !1,style: {x: m,y: c,width: p,height: u - c,color: t[d % i]}}, this.shapeList.push(new o(e)), u = c
            } else
                e = {zlevel: this.getZlevelBase(),z: this.getZBase(),hoverable: !1,style: {x: this.grid.getX(),y: this.grid.getY(),width: this.grid.getWidth(),height: this.grid.getHeight(),color: t}}, this.shapeList.push(new o(e))
        },_calculateValue: function() {
            if (isNaN(this.option.min - 0) || isNaN(this.option.max - 0)) {
                for (var e, t, i = {}, n = this.component.legend, a = 0, o = this.series.length; o > a; a++)
                    !(this.series[a].type != r.CHART_TYPE_LINE && this.series[a].type != r.CHART_TYPE_BAR && this.series[a].type != r.CHART_TYPE_SCATTER && this.series[a].type != r.CHART_TYPE_K && this.series[a].type != r.CHART_TYPE_EVENTRIVER || n && !n.isSelected(this.series[a].name) || (e = this.series[a].xAxisIndex || 0, t = this.series[a].yAxisIndex || 0, this.option.xAxisIndex != e && this.option.yAxisIndex != t || !this._calculSum(i, a)));
                var s;
                for (var a in i) {
                    s = i[a];
                    for (var l = 0, h = s.length; h > l; l++)
                        if (!isNaN(s[l])) {
                            this._hasData = !0, this._min = s[l], this._max = s[l];
                            break
                        }
                    if (this._hasData)
                        break
                }
                for (var a in i) {
                    s = i[a];
                    for (var l = 0, h = s.length; h > l; l++)
                        isNaN(s[l]) || (this._min = Math.min(this._min, s[l]), this._max = Math.max(this._max, s[l]))
                }
                var d = "log" !== this.option.type ? this.option.boundaryGap : [0, 0], c = Math.abs(this._max - this._min);
                this._min = isNaN(this.option.min - 0) ? this._min - Math.abs(c * d[0]) : this.option.min - 0, this._max = isNaN(this.option.max - 0) ? this._max + Math.abs(c * d[1]) : this.option.max - 0, this._min === this._max && (0 === this._max ? this._max = 1 : this._max > 0 ? this._min = this._max / this.option.splitNumber != null ? this.option.splitNumber : 5 : this._max = this._max / this.option.splitNumber != null ? this.option.splitNumber : 5), "time" === this.option.type ? this._reformTimeValue() : "log" === this.option.type ? this._reformLogValue() : this._reformValue(this.option.scale)
            } else
                this._hasData = !0, this._min = this.option.min - 0, this._max = this.option.max - 0, "time" === this.option.type ? this._reformTimeValue() : "log" === this.option.type ? this._reformLogValue() : this._customerValue()
        },_calculSum: function(e, t) {
            var i, n, a = this.series[t].name || "kener";
            if (this.series[t].stack) {
                var o = "__Magic_Key_Positive__" + this.series[t].stack, l = "__Magic_Key_Negative__" + this.series[t].stack;
                e[o] = e[o] || [], e[l] = e[l] || [], e[a] = e[a] || [], n = this.series[t].data;
                for (var h = 0, d = n.length; d > h; h++)
                    i = this.getDataFromOption(n[h]), "-" !== i && (i -= 0, i >= 0 ? null != e[o][h] ? e[o][h] += i : e[o][h] = i : null != e[l][h] ? e[l][h] += i : e[l][h] = i, this.option.scale && e[a].push(i))
            } else if (e[a] = e[a] || [], this.series[t].type != r.CHART_TYPE_EVENTRIVER) {
                n = this.series[t].data;
                for (var h = 0, d = n.length; d > h; h++)
                    i = this.getDataFromOption(n[h]), this.series[t].type === r.CHART_TYPE_K ? (e[a].push(i[0]), e[a].push(i[1]), e[a].push(i[2]), e[a].push(i[3])) : i instanceof Array ? (-1 != this.option.xAxisIndex && e[a].push("time" != this.option.type ? i[0] : s.getNewDate(i[0])), -1 != this.option.yAxisIndex && e[a].push("time" != this.option.type ? i[1] : s.getNewDate(i[1]))) : e[a].push(i)
            } else {
                n = this.series[t].data;
                for (var h = 0, d = n.length; d > h; h++)
                    for (var c = n[h].evolution, m = 0, p = c.length; p > m; m++)
                        e[a].push(s.getNewDate(c[m].time))
            }
        },_reformValue: function(t) {
            var i = e("../util/smartSteps"), n = this.option.splitNumber;
            !t && this._min >= 0 && this._max >= 0 && (this._min = 0), !t && this._min <= 0 && this._max <= 0 && (this._max = 0);
            var a = i(this._min, this._max, n);
            n = null != n ? n : a.secs, this._min = a.min, this._max = a.max, this._valueList = a.pnts, this._reformLabelData()
        },_reformTimeValue: function() {
            var e = null != this.option.splitNumber ? this.option.splitNumber : 5, t = s.getAutoFormatter(this._min, this._max, e), i = t.formatter, n = t.gapValue;
            this._valueList = [s.getNewDate(this._min)];
            var a;
            switch (i) {
                case "week":
                    a = s.nextMonday(this._min);
                    break;
                case "month":
                    a = s.nextNthOnMonth(this._min, 1);
                    break;
                case "quarter":
                    a = s.nextNthOnQuarterYear(this._min, 1);
                    break;
                case "half-year":
                    a = s.nextNthOnHalfYear(this._min, 1);
                    break;
                case "year":
                    a = s.nextNthOnYear(this._min, 1);
                    break;
                default:
                    72e5 >= n ? a = (Math.floor(this._min / n) + 1) * n : (a = s.getNewDate(this._min - -n), a.setHours(6 * Math.round(a.getHours() / 6)), a.setMinutes(0), a.setSeconds(0))
            }
            for (a - this._min < n / 2 && (a -= -n), t = s.getNewDate(a), e *= 1.5; e-- >= 0 && (("month" == i || "quarter" == i || "half-year" == i || "year" == i) && t.setDate(1), !(this._max - t < n / 2)); )
                this._valueList.push(t), t = s.getNewDate(t - -n);
            this._valueList.push(s.getNewDate(this._max)), this._reformLabelData(function(e) {
                return function(t) {
                    return s.format(e, t)
                }
            }(i))
        },_customerValue: function() {
            var t = e("../util/accMath"), i = null != this.option.splitNumber ? this.option.splitNumber : 5, n = (this._max - this._min) / i;
            
            this._valueList = [];
            for (var a = 0; i >= a; a++)
                this._valueList.push(t.accAdd(this._min, t.accMul(n, a)));
            this._reformLabelData()
        },_reformLogValue: function() {
            var t = this.option, i = e("../util/smartLogSteps")({dataMin: this._min,dataMax: this._max,logPositive: t.logPositive,logLabelBase: t.logLabelBase,splitNumber: t.splitNumber});
            this._min = i.dataMin, this._max = i.dataMax, this._valueList = i.tickList, this._dataMappingMethods = i.dataMappingMethods, this._reformLabelData(i.labelFormatter)
        },_reformLabelData: function(e) {
            this._valueLabel = [];
            var t = this.option.axisLabel.formatter;
            if (t)
                for (var i = 0, n = this._valueList.length; n > i; i++)
                    "function" == typeof t ? this._valueLabel.push(e ? t.call(this.myChart, this._valueList[i], e) : t.call(this.myChart, this._valueList[i])) : "string" == typeof t && this._valueLabel.push(e ? s.format(t, this._valueList[i]) : t.replace("{value}", this._valueList[i]));
            else
                for (var i = 0, n = this._valueList.length; n > i; i++)
                    this._valueLabel.push(e ? e(this._valueList[i]) : this.numAddCommas(this._valueList[i]))
        },getExtremum: function() {
            this._calculateValue();
            var e = this._dataMappingMethods;
            return {min: this._min,max: this._max,dataMappingMethods: e ? l.merge({}, e) : null}
        },refresh: function(e, t) {
            e && (this.option = this.reformOption(e), this.option.axisLabel.textStyle = l.merge(this.option.axisLabel.textStyle || {}, this.ecTheme.textStyle), this.series = t), this.zr && (this.clear(), this._buildShape())
        },getCoord: function(e) {
            this._dataMappingMethods && (e = this._dataMappingMethods.value2Coord(e)), e = e < this._min ? this._min : e, e = e > this._max ? this._max : e;
            var t;
            return t = this.isHorizontal() ? this.grid.getX() + (e - this._min) / (this._max - this._min) * this.grid.getWidth() : this.grid.getYend() - (e - this._min) / (this._max - this._min) * this.grid.getHeight()
        },getCoordSize: function(e) {
            return Math.abs(this.isHorizontal() ? e / (this._max - this._min) * this.grid.getWidth() : e / (this._max - this._min) * this.grid.getHeight())
        },getValueFromCoord: function(e) {
            var t;
            return this.isHorizontal() ? (e = e < this.grid.getX() ? this.grid.getX() : e, e = e > this.grid.getXend() ? this.grid.getXend() : e, t = this._min + (e - this.grid.getX()) / this.grid.getWidth() * (this._max - this._min)) : (e = e < this.grid.getY() ? this.grid.getY() : e, e = e > this.grid.getYend() ? this.grid.getYend() : e, t = this._max - (e - this.grid.getY()) / this.grid.getHeight() * (this._max - this._min)), this._dataMappingMethods && (t = this._dataMappingMethods.coord2Value(t)), t.toFixed(2) - 0
        },isMaindAxis: function(e) {
            for (var t = 0, i = this._valueList.length; i > t; t++)
                if (this._valueList[t] === e)
                    return !0;
            return !1
        }}, l.inherits(t, i), e("../component").define("valueAxis", t), t
}), define("echarts/util/date", [], function() {
    function e(e, t, i) {
        i = i > 1 ? i : 2;
        for (var n, a, o, r, s = 0, l = d.length; l > s; s++)
            if (n = d[s].value, a = Math.ceil(t / n) * n - Math.floor(e / n) * n, Math.round(a / n) <= 1.2 * i) {
                o = d[s].formatter, r = d[s].value;
                break
            }
        return null == o && (o = "year", n = 317088e5, a = Math.ceil(t / n) * n - Math.floor(e / n) * n, r = Math.round(a / (i - 1) / n) * n), {formatter: o,gapValue: r}
    }
    function t(e) {
        return 10 > e ? "0" + e : e
    }
    function i(e, i) {
        ("week" == e || "month" == e || "quarter" == e || "half-year" == e || "year" == e) && (e = "MM - dd\nyyyy");
        var n = h(i), a = n.getFullYear(), o = n.getMonth() + 1, r = n.getDate(), s = n.getHours(), l = n.getMinutes(), d = n.getSeconds();
        return e = e.replace("MM", t(o)), e = e.toLowerCase(), e = e.replace("yyyy", a), e = e.replace("yy", a % 100), e = e.replace("dd", t(r)), e = e.replace("d", r), e = e.replace("hh", t(s)), e = e.replace("h", s), e = e.replace("mm", t(l)), e = e.replace("m", l), e = e.replace("ss", t(d)), e = e.replace("s", d)
    }
    function n(e) {
        return e = h(e), e.setDate(e.getDate() + 8 - e.getDay()), e
    }
    function a(e, t, i) {
        return e = h(e), e.setMonth(Math.ceil((e.getMonth() + 1) / i) * i), e.setDate(t), e
    }
    function o(e, t) {
        return a(e, t, 1)
    }
    function r(e, t) {
        return a(e, t, 3)
    }
    function s(e, t) {
        return a(e, t, 6)
    }
    function l(e, t) {
        return a(e, t, 12)
    }
    function h(e) {
        return e instanceof Date ? e : new Date("string" == typeof e ? e.replace(/-/g, "/") : e)
    }
    var d = [{formatter: "hh : mm : ss",value: 1e3}, {formatter: "hh : mm : ss",value: 5e3}, {formatter: "hh : mm : ss",value: 1e4}, {formatter: "hh : mm : ss",value: 15e3}, {formatter: "hh : mm : ss",value: 3e4}, {formatter: "hh : mm\nMM - dd",value: 6e4}, {formatter: "hh : mm\nMM - dd",value: 3e5}, {formatter: "hh : mm\nMM - dd",value: 6e5}, {formatter: "hh : mm\nMM - dd",value: 9e5}, {formatter: "hh : mm\nMM - dd",value: 18e5}, {formatter: "hh : mm\nMM - dd",value: 36e5}, {formatter: "hh : mm\nMM - dd",value: 72e5}, {formatter: "hh : mm\nMM - dd",value: 216e5}, {formatter: "hh : mm\nMM - dd",value: 432e5}, {formatter: "MM - dd\nyyyy",value: 864e5}, {formatter: "week",value: 6048e5}, {formatter: "month",value: 26784e5}, {formatter: "quarter",value: 8208e6}, {formatter: "half-year",value: 16416e6}, {formatter: "year",value: 32832e6}];
    return {getAutoFormatter: e,getNewDate: h,format: i,nextMonday: n,nextNthPerNmonth: a,nextNthOnMonth: o,nextNthOnQuarterYear: r,nextNthOnHalfYear: s,nextNthOnYear: l}
}), define("echarts/util/smartSteps", [], function() {
    function e(e) {
        return w.log(S(e)) / w.LN10
    }
    function t(e) {
        return w.pow(10, e)
    }
    function i(e) {
        return e === X(e)
    }
    function n(e, t, n, a) {
        y = a || {}, b = y.steps || v, _ = y.secs || L, n = W(+n || 0) % 99, e = +e || 0, t = +t || 0, x = k = 0, "min" in y && (e = +y.min || 0, x = 1), "max" in y && (t = +y.max || 0, k = 1), e > t && (t = [e, e = t][0]);
        var o = t - e;
        if (x && k)
            return f(e, t, n);
        if ((n || 5) > o) {
            if (i(e) && i(t))
                return p(e, t, n);
            if (0 === o)
                return u(e, t, n)
        }
        return h(e, t, n)
    }
    function a(e, i, n, a) {
        a = a || 0;
        var s = o((i - e) / n, -1), l = o(e, -1, 1), h = o(i, -1), d = w.min(s.e, l.e, h.e);
        0 === l.c ? d = w.min(s.e, h.e) : 0 === h.c && (d = w.min(s.e, l.e)), r(s, {c: 0,e: d}), r(l, s, 1), r(h, s), a += d, e = l.c, i = h.c;
        for (var c = (i - e) / n, m = t(a), p = 0, u = [], V = n + 1; V--; )
            u[V] = (e + c * V) * m;
        if (0 > a) {
            p = U(m), c = +(c * m).toFixed(p), e = +(e * m).toFixed(p), i = +(i * m).toFixed(p);
            for (var V = u.length; V--; )
                u[V] = u[V].toFixed(p), 0 === +u[V] && (u[V] = "0")
        } else
            e *= m, i *= m, c *= m;
        return _ = 0, b = 0, y = 0, {min: e,max: i,secs: n,step: c,fix: p,exp: a,pnts: u}
    }
    function o(n, a, o) {
        a = W(a % 10) || 2, 0 > a && (i(n) ? a = ("" + S(n)).replace(/0+$/, "").length || 1 : (n = n.toFixed(15).replace(/0+$/, ""), a = n.replace(".", "").replace(/^[-0]+/, "").length, n = +n));
        var r = X(e(n)) - a + 1, s = +(n * t(-r)).toFixed(15) || 0;
        return s = o ? X(s) : I(s), !s && (r = 0), ("" + S(s)).length > a && (r += 1, s /= 10), {c: s,e: r}
    }
    function r(e, i, n) {
        var a = i.e - e.e;
        a && (e.e += a, e.c *= t(-a), e.c = n ? X(e.c) : I(e.c))
    }
    function s(e, t, i) {
        e.e < t.e ? r(t, e, i) : r(e, t, i)
    }
    function l(e, t) {
        t = t || v, e = o(e);
        for (var i = e.c, n = 0; i > t[n]; )
            n++;
        if (!t[n])
            for (i /= 10, e.e += 1, n = 0; i > t[n]; )
                n++;
        return e.c = t[n], e
    }
    function h(e, t, n) {
        var s, h = n || +_.slice(-1), u = l((t - e) / h, b), U = o(t - e), f = o(e, -1, 1), y = o(t, -1);
        if (r(U, u), r(f, u, 1), r(y, u), n ? s = c(f, y, h) : h = d(f, y), i(e) && i(t) && e * t >= 0) {
            if (h > t - e)
                return p(e, t, h);
            h = m(e, t, n, f, y, h)
        }
        var v = V(e, t, f.c, y.c);
        return f.c = v[0], y.c = v[1], (x || k) && g(e, t, f, y), a(f.c, y.c, h, y.e)
    }
    function d(e, i) {
        for (var n, a, o, r, s = [], h = _.length; h--; )
            n = _[h], a = l((i.c - e.c) / n, b), a = a.c * t(a.e), o = X(e.c / a) * a, r = I(i.c / a) * a, s[h] = {min: o,max: r,step: a,span: r - o};
        return s.sort(function(e, t) {
            var i = e.span - t.span;
            return 0 === i && (i = e.step - t.step), i
        }), s = s[0], n = s.span / s.step, e.c = s.min, i.c = s.max, 3 > n ? 2 * n : n
    }
    function c(e, i, n) {
        for (var a, o, r = i.c, s = (i.c - e.c) / n - 1; r > e.c; )
            s = l(s + 1, b), s = s.c * t(s.e), a = s * n, o = I(i.c / s) * s, r = o - a;
        var h = e.c - r, d = o - i.c, c = h - d;
        return c > 1.1 * s && (c = W(c / s / 2) * s, r += c, o += c), e.c = r, i.c = o, s
    }
    function m(e, n, a, o, r, s) {
        var l = r.c - o.c, h = l / s * t(r.e);
        if (!i(h) && (h = X(h), l = h * s, n - e > l && (h += 1, l = h * s, !a && h * (s - 1) >= n - e && (s -= 1, l = h * s)), l >= n - e)) {
            var d = l - (n - e);
            o.c = W(e - d / 2), r.c = W(n + d / 2), o.e = 0, r.e = 0
        }
        return s
    }
    function p(e, t, i) {
        if (i = i || 5, x)
            t = e + i;
        else if (k)
            e = t - i;
        else {
            var n = i - (t - e), o = W(e - n / 2), r = W(t + n / 2), s = V(e, t, o, r);
            e = s[0], t = s[1]
        }
        return a(e, t, i)
    }
    function u(e, t, i) {
        i = i || 5;
        var n = w.min(S(t / i), i) / 2.1;
        return x ? t = e + n : k ? e = t - n : (e -= n, t += n), h(e, t, i)
    }
    function V(e, t, i, n) {
        return e >= 0 && 0 > i ? (n -= i, i = 0) : 0 >= t && n > 0 && (i -= n, n = 0), [i, n]
    }
    function U(e) {
        return e = (+e).toFixed(15).split("."), e.pop().replace(/0+$/, "").length
    }
    function g(e, t, i, n) {
        if (x) {
            var a = o(e, 4, 1);
            i.e - a.e > 6 && (a = {c: 0,e: i.e}), s(i, a), s(n, a), n.c += a.c - i.c, i.c = a.c
        } else if (k) {
            var r = o(t, 4);
            n.e - r.e > 6 && (r = {c: 0,e: n.e}), s(i, r), s(n, r), i.c += r.c - n.c, n.c = r.c
        }
    }
    function f(e, t, i) {
        var n = i ? [i] : _, s = t - e;
        if (0 === s)
            return t = o(t, 3), i = n[0], t.c = W(t.c + i / 2), a(t.c - i, t.c, i, t.e);
        S(t / s) < 1e-6 && (t = 0), S(e / s) < 1e-6 && (e = 0);
        var l, h, d, c = [[5, 10], [10, 2], [50, 10], [100, 2]], m = [], p = [], u = o(t - e, 3), V = o(e, -1, 1), U = o(t, -1);
        r(V, u, 1), r(U, u), s = U.c - V.c, u.c = s;
        for (var g = n.length; g--; ) {
            i = n[g], l = I(s / i), h = l * i - s, d = 3 * (h + 3), d += 2 * (i - n[0] + 2), i % 5 === 0 && (d -= 10);
            for (var f = c.length; f--; )
                l % c[f][0] === 0 && (d /= c[f][1]);
            p[g] = [i, l, h, d].join(), m[g] = {secs: i,step: l,delta: h,score: d}
        }
        return m.sort(function(e, t) {
            return e.score - t.score
        }), m = m[0], V.c = W(V.c - m.delta / 2), U.c = W(U.c + m.delta / 2), a(V.c, U.c, m.secs, u.e)
    }
    var y, b, _, x, k, v = [10, 20, 25, 50], L = [4, 5, 6], w = Math, W = w.round, X = w.floor, I = w.ceil, S = w.abs;
    return n
}), define("echarts/util/smartLogSteps", ["require", "./number"], function(e) {
    function t(e) {
        return i(), U = e || {}, n(), a(), [o(), i()][0]
    }
    function i() {
        m = U = f = V = y = b = g = _ = p = u = null
    }
    function n() {
        p = U.logLabelBase, null == p ? (u = "plain", p = 10, V = S) : (p = +p, 1 > p && (p = 10), u = "exponent", V = v(p)), g = U.splitNumber, null == g && (g = E);
        var e = parseFloat(U.dataMin), t = parseFloat(U.dataMax);
        isFinite(e) || isFinite(t) ? isFinite(e) ? isFinite(t) ? e > t && (t = [e, e = t][0]) : t = e : e = t : e = t = 1, m = U.logPositive, null == m && (m = t > 0 || 0 === e), y = m ? e : -t, b = m ? t : -e, T > y && (y = T), T > b && (b = T)
    }
    function a() {
        function e() {
            g > d && (g = d);
            var e = X(l(d / g)), t = W(l(d / e)), i = e * t, n = (i - m) / 2, a = X(l(r - n));
            c(a - r) && (a -= 1), f = -a * V;
            for (var s = a; o >= s - e; s += e)
                _.push(L(p, s))
        }
        function t() {
            for (var e = i(h, 0), t = e + 2; t > e && a(e + 1) + n(e + 1) * C < r; )
                e++;
            for (var l = i(s, 0), t = l - 2; l > t && a(l - 1) + n(l - 1) * C > o; )
                l--;
            f = -(a(e) * S + n(e) * K);
            for (var d = e; l >= d; d++) {
                var c = a(d), m = n(d);
                _.push(L(10, c) * L(2, m))
            }
        }
        function i(e, t) {
            return 3 * e + t
        }
        function n(e) {
            return e - 3 * a(e)
        }
        function a(e) {
            return X(l(e / 3))
        }
        _ = [];
        var o = l(v(b) / V), r = l(v(y) / V), s = W(o), h = X(r), d = s - h, m = o - r;
        "exponent" === u ? e() : z >= d && g > z ? t() : e()
    }
    function o() {
        for (var e = [], t = 0, i = _.length; i > t; t++)
            e[t] = (m ? 1 : -1) * _[t];
        !m && e.reverse();
        var n = s(), a = n.value2Coord, o = a(e[0]), l = a(e[e.length - 1]);
        return o === l && (o -= 1, l += 1), {dataMin: o,dataMax: l,tickList: e,logPositive: m,labelFormatter: r(),dataMappingMethods: n}
    }
    function r() {
        if ("exponent" === u) {
            var e = p, t = V;
            return function(i) {
                if (!isFinite(parseFloat(i)))
                    return "";
                var n = "";
                return 0 > i && (i = -i, n = "-"), n + e + d(v(i) / t)
            }
        }
        return function(e) {
            return isFinite(parseFloat(e)) ? x.addCommas(h(e)) : ""
        }
    }
    function s() {
        var e = m, t = f;
        return {value2Coord: function(i) {
                return null == i || isNaN(i) || !isFinite(i) ? i : (i = parseFloat(i), isFinite(i) ? e && T > i ? i = T : !e && i > -T && (i = -T) : i = T, i = w(i), (e ? 1 : -1) * (v(i) + t))
            },coord2Value: function(i) {
                return null == i || isNaN(i) || !isFinite(i) ? i : (i = parseFloat(i), isFinite(i) || (i = T), e ? L(I, i - t) : -L(I, -i + t))
            }}
    }
    function l(e) {
        return +Number(+e).toFixed(14)
    }
    function h(e) {
        return Number(e).toFixed(15).replace(/\.?0*$/, "")
    }
    function d(e) {
        e = h(Math.round(e));
        for (var t = [], i = 0, n = e.length; n > i; i++) {
            var a = e.charAt(i);
            t.push(A[a] || "")
        }
        return t.join("")
    }
    function c(e) {
        return e > -T && T > e
    }
    var m, p, u, V, U, g, f, y, b, _, x = e("./number"), k = Math, v = k.log, L = k.pow, w = k.abs, W = k.ceil, X = k.floor, I = k.E, S = k.LN10, K = k.LN2, C = K / S, T = 1e-9, E = 5, z = 2, A = {0: "⁰",1: "¹",2: "²",3: "³",4: "⁴",5: "⁵",6: "⁶",7: "⁷",8: "⁸",9: "⁹","-": "⁻"};
    return t
});
